记录编号 124437 评测结果 AAAAAAAAAA
题目名称 [NOIP 2006]能量项链 最终得分 100
用户昵称 Gravatar乌龙猹 是否通过 通过
代码语言 C++ 运行时间 0.004 s
提交时间 2014-10-04 06:16:40 内存使用 0.44 MiB
显示代码纯文本
#include<cstdio>
using namespace std;
int n,a[202],tot2=0;
int f_max[201][201];
int main()
{
	freopen("energy.in","r",stdin);
    freopen("energy.out","w",stdout);
	scanf("%d",&n);
	for(int i=1;i<=n;i++) scanf("%d",&a[i]),a[i+n]=a[i];
	a[2*n+1]=a[1];
	for(int d=2;d<=n;d++)
	{
		for(int i=1;i<=2*n-d+1;i++)
		{
			int j=i+d-1,kk=i;
			for(int k=i;k<j;k++)
			{
				if(f_max[i][k]+f_max[k+1][j]+a[i]*a[k+1]*a[j+1]>f_max[i][j]) 
					f_max[i][j]=f_max[i][k]+f_max[k+1][j]+a[i]*a[k+1]*a[j+1];
			}//赋值语句直接在里边加,开始用的以前的代码结果就呵呵了;
			if(f_max[i][i+n-1]>tot2) tot2=f_max[i][i+n-1];
		}
	}
	printf("%d",tot2);
}