AcWing 1027. 方格取数
原题链接
简单
作者:
stedv
,
2019-09-23 14:56:02
,
所有人可见
,
阅读 893
#include<bits/stdc++.h>
using namespace std;
const int N=11;
int s[N][N][N][N],a[N][N],n,x,y,z;
int main()
{
scanf("%d",&n);
while(scanf("%d%d%d",&x,&y,&z),x&&y&&z)
{
a[x][y]=z;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
for(int k=1;k<=n;k++)
for(int l=1;l<=n;l++)
{
s[i][j][k][l]=max(s[i-1][j][k-1][l],max(s[i-1][j][k][l-1],max(s[i][j-1][k][l-1],s[i][j-1][k-1][l])))+a[i][j]+a[k][l];
if(i==k&&j==l)s[i][j][k][l]-=a[i][j];
}
printf("%d",s[n][n][n][n]);
return 0;
}
加油
被踩的好可怜