代码:
#include <iostream>
#include <stdio.h>
#include <algorithm>
using namespace std;
int dp[105][105];
int main()
{
int n;
while(cin>>n){
for(int i=1;i<=n;i++){
for(int j=1;j<=i;j++){
cin>>dp[i][j];
}
}
for(int i=n;i>1;i--){
for(int j=1;j<i;j++){
dp[i-1][j]=dp[i-1][j]+max(dp[i][j],dp[i][j+1]);
}
}
//写出状态方程,剩下的交给递归实现
cout<<dp[1][1]<<endl;
}
return 0;
}