记录编号 |
248101 |
评测结果 |
AAAAA |
题目名称 |
石子合并(加强版) |
最终得分 |
100 |
用户昵称 |
Hzoi_ |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.000 s |
提交时间 |
2016-04-10 07:21:28 |
内存使用 |
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;
- }