RingTouSou @ 2023-10-07 00:40:01
#include<bits/stdc++.h>
using namespace std;
const int N=1005;
int n,a[N][N],f[N][N];
int dfs(int x,int y)
{
if(f[x][y]!=-1)
{
return f[x][y];//记忆化搜索
}
if(x==n)
{
return f[x][y]=a[x][y]; //到边界直接取
}
return f[x][y]=max(dfs(x+1,y),dfs(x+1,y+1))+a[x][y];
//记录左右哪个大并取 加上自身
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=i;j++)
{
cin>>a[i][j];
}
}
memset(f,-1,sizeof(f));
dfs(1,1);
cout<<f[1][1];
}
详情见f数组
by xiaoming007 @ 2023-10-08 17:59:39
@RingTouSou 所有输入范围