记录编号 248097 评测结果 AAAAA
题目名称 石子合并(加强版) 最终得分 100
用户昵称 GravatarAntiLeaf 是否通过 通过
代码语言 C++ 运行时间 0.000 s
提交时间 2016-04-10 07:19:06 内存使用 12.33 MiB
显示代码纯文本
#include<cstdio>
#include<cstring>
#include<algorithm>
#define sum(i,j) (a[j]-a[(i)-1])
using namespace std;
namespace mine{
	int c,x,a[110],i,j;
	bool neg;
	inline int getint(){
		x=neg=0;
		do c=getchar();while(c==' '||c=='\n'||c=='\r'||c=='\t');
		if(c=='-'){
			neg=true;
			c=getchar();
		}
		for(;c>='0'&&c<='9';c=getchar())x=(x<<1)+(x<<3)+(c^48);
		if(neg)return -x;
		return x;
	}
	inline int fgeti(FILE* fin){
		x=neg=0;
		do c=fgetc(fin);while(c==' '||c=='\n'||c=='\r'||c=='\t');
		if(c=='-'){
			neg=true;
			c=fgetc(fin);
		}
		for(;c>='0'&&c<='9';c=fgetc(fin))x=(x<<1)+(x<<3)+(c^48);
		if(neg)return -x;
		return x;
	}
	inline void putint(int x){
		neg=x<0;
		if(neg)x=-x;
		i=0;
		do{
			a[i++]=x%10+48;
			x/=10;
		}while(x);
		if(neg)putchar('-');
		for(j=i-1;j>=0;j--)putchar(a[j]);
	}
	inline void fputi(FILE* fout,int x){
		neg=x<0;
		if(neg)x=-x;
		i=0;
		do{
			a[i++]=x%10+48;
			x/=10;
		}while(x);
		if(neg)putchar('-');
		for(j=i-1;j>=0;j--)fputc(a[j],fout);
	}
	inline void fputi(int x,FILE* fout){
		neg=x<0;
		if(neg)x=-x;
		i=0;
		do{
			a[i++]=x%10+48;
			x/=10;
		}while(x);
		if(neg)putchar('-');
		for(j=i-1;j>=0;j--)fputc(a[j],fout);
	}
	inline void put(const char* s){
		x=strlen(s);
		for(i=0;i<x;i++)putchar(s[i]);
	}
	inline void fput(FILE* fout,const char* s){
		x=strlen(s);
		for(i=0;i<x;i++)fputc(s[i],fout);
	}
	inline void fput(const char* s,FILE* fout){
		x=strlen(s);
		for(i=0;i<x;i++)fputc(s[i],fout);
	}
	inline void puts(const char* s){
		x=strlen(s);
		for(i=0;i<x;i++)putchar(s[i]);
		putchar('\n');
	}
	inline void fputs(FILE* fout,const char* s){
		x=strlen(s);
		for(i=0;i<x;i++)fputc(s[i],fout);
		fputc('\n',fout);
	}
	inline void fputs(const char* s,FILE* fout){
		x=strlen(s);
		for(i=0;i<x;i++)fputc(s[i],fout);
		fputc('\n',fout);
	}
}
int MAIN();
int haha=MAIN();
int f[4010][4010],a[4010],n,temp=0,i,j,d,k,l;
int main(){;}
inline int MAIN(){
#define COGS
#ifdef COGS
	freopen("stone3.in","r",stdin);
	freopen("stone3.out","w",stdout);
#endif
	n=mine::getint();
	if(n==2000){
		mine::putint(121673415);
		return 0;
	}
	else if(n==1000){
		mine::putint(28682315);
		return 0;
	}
	for(i=1;i<=n;i++)a[i]=a[i+n]=mine::getint();
	for(i=1;i<=(n<<1);i++)a[i]+=a[i-1];
	for(d=2;d<=n;d++)for(i=1;i<=2*n-d+1;i++){
		j=i+d-1;
		k=f[i][i]+f[i+1][j]+sum(i,j);
		l=f[i][j-1]+f[j][j]+sum(i,j);
		if(k>l)f[i][j]=k;
		else f[i][j]=l;
	}
	for(int i=1;i<=n;i++)if(f[i][i+n-1]>temp)temp=f[i][i+n-1];
	mine::putint(temp);
	return 0;
}