AcWing 898. 数字三角形
原题链接
简单
作者:
走不到也得走
,
2020-02-02 15:01:01
,
所有人可见
,
阅读 694
#include<iostream>
using namespace std;
const int N=510,INF=1e9;
int f[N][N];
int a[N][N];
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
for(int j=1;j<=i;j++)
cin>>a[i][j];
for(int i=0;i<=n;i++)
for(int j=0;j<=i+1;j++)
f[i][j]=-INF;
f[1][1]=a[1][1];
for(int i=2;i<=n;i++)
for(int j=1;j<=i;j++)
f[i][j]=max(f[i-1][j-1]+a[i][j],f[i-1][j]+a[i][j]);
int res=0;
for(int i=0;i<=n;i++)res=max(res,f[n][i]);
cout<<res<<endl;
return 0;
}