记录编号 446437 评测结果 AAAAAAAAAA
题目名称 [NOIP 2006]能量项链 最终得分 100
用户昵称 Gravatar玉带林中挂 是否通过 通过
代码语言 C++ 运行时间 0.008 s
提交时间 2017-09-08 11:11:20 内存使用 0.47 MiB
显示代码纯文本
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdlib>
using namespace std;
int n,a[202],tot=0;
int f_max[201][201];
inline int read()
{
	int x=0,f=1;
	char ch=getchar();
	while(ch<'0'||ch>'9')
	{
		if(ch=='-')f=-1;
		ch=getchar();
	}
	while(ch>='0'&&ch<='9')
	{
		x=x*10+ch-'0';
		ch=getchar();
	}
	return x*f;
}
int main()
{
	freopen("energy.in","r",stdin);freopen("energy.out","w",stdout);
	n=read();
	for(int i=1;i<=n;i++) 
	{
		a[i]=read();
		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]>tot) tot=f_max[i][i+n-1];
		}
	}
	printf("%d",tot);
	fclose(stdin);fclose(stdout);
	return 0;
}