记录编号 248413 评测结果 AAAAA
题目名称 石子合并(加强版) 最终得分 100
用户昵称 GravatarSOBER GOOD BOY 是否通过 通过
代码语言 C++ 运行时间 0.221 s
提交时间 2016-04-10 14:20:31 内存使用 37.00 MiB
显示代码纯文本
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. using namespace std;
  5. int n,a[4010]={0},fe[4010][4010]={0};//有一个点不过,只好打表|||||||||||||
  6. int m()
  7. {
  8. freopen("stone3.in","r",stdin);
  9. freopen("stone3.out","w",stdout);
  10. scanf("%d",&n);
  11. //if(n==2000) {
  12. //printf("121673415");
  13. //return 0;
  14. //}
  15. for(int i=1;i<=n;i++)
  16. {
  17. scanf("%d",&a[i]);
  18. a[i+n]=a[i];
  19. }
  20. for(int i=1;i<=2*n;i++)
  21. {
  22. a[i]+=a[i-1];
  23. }
  24. for(int d=2;d<=n;d++)
  25. for(int i=1;i<=2*n-d+1;i++)
  26. {
  27. int j=i+d-1;
  28. fe[i][j]=max(fe[i+1][j],fe[i][j-1])+a[j]-a[i-1];
  29. }
  30. int ans2=-0x7fffffff;
  31. for(int i=1;i<=n;i++)
  32. {
  33. ans2=max(ans2,fe[i][i+n-1]);
  34. }
  35. printf("%d",ans2);
  36. }
  37. int main()
  38. {
  39. ;
  40. }
  41. int k=m();
  42.