记录编号 247924 评测结果 AAAAA
题目名称 石子合并(加强版) 最终得分 100
用户昵称 GravatarRespawn 是否通过 通过
代码语言 C++ 运行时间 0.879 s
提交时间 2016-04-09 20:41:46 内存使用 98.02 MiB
显示代码纯文本
//利用优化 
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=4002;
int h[maxn],f[maxn][maxn],a[maxn][maxn];
void Init();
int main()
{
	freopen("stone3.in","r",stdin);
	freopen("stone3.out","w",stdout);
	Init();
	return 0;
}
void Init()
{
	int n;
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		scanf("%d",&h[i]);
		h[i+n]=h[i];
	}
	for(int i=1;i<=2*n;i++)
	{
		for(int j=1;j<=2*n;j++)
		{
			if(i==j)
			{
				a[i][j]=h[i];
			}
			else
			{
				a[i][j]=a[i][j-1]+h[j];
			}
		}
	}
	int ans=0;
	for(int d=2;d<=n;d++)
	{
		for(int i=1;i<=2*n-d+1;i++)
		{
			int j=i+d-1;
			int p=max(f[i][i]+f[i+1][j]+a[i][j],f[i][j-1]+f[j][j]+a[i][j]);
			f[i][j]=p;
			if(d==n&&ans<f[i][j])
			{
				ans=f[i][j];
			}
		}
		
	}
	
	printf("%d",ans);
}