记录编号 132782 评测结果 AAAAAAAAAA
题目名称 删数 最终得分 100
用户昵称 Gravatar水中音 是否通过 通过
代码语言 C++ 运行时间 0.148 s
提交时间 2014-10-26 17:10:59 内存使用 3.23 MiB
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<queue>
#include<string>
using namespace std;
int n,i,j,k,m,p,zj1,zj2,zj3,b,a[101]={0},zui=0;
int f[101][101]={0},zhi[101][101]={0};
void work()
{
	for(i=1;i<=n;i++)
	{
		zj1=n-i+1;
		for(zj2=i,p=1;p<=zj1;p++,zj2++)
		{
			zhi[p][zj2]=i*(a[zj2]-a[p]);
			if(zhi[p][zj2]<0)zhi[p][zj2]*=-1;
		}
	}
	for(i=1;i<=n;i++)zhi[i][i]=a[i];
}
int main()
{
	freopen("remove.in","r",stdin);
	freopen("remove.out","w",stdout);
	scanf("%d",&n);
	for(i=1;i<=n;i++)
	scanf("%d",&a[i]);
	work();
    for(i=0;i<=n;i++)
	for(p=n+1;p>i;p--)
	{
		for(k=0;k<=i;k++)
		{
			for(j=n+1;j>=p;j--)
			{
				zj1=f[k][j]+zhi[k+1][i]+zhi[p][j-1];
				if(zj1>f[i][p]) f[i][p]=zj1;
			}
		}
		if(f[i][p]>zui)zui=f[i][p];
	}
    printf("%d\n",zui);
	return 0;
}