代码如下:
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 610; // 数字三角形的最大行数
int triangle[MAXN][MAXN]; // 存储数字三角形中的数字
int dp[MAXN][MAXN]; // 存储从三角形顶部到该位置的最大路径和
int main()
{
int n;
cin >> n;
// 输入数字三角形
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= i; j++) {
cin >> triangle[i][j];
}
}
// 初始化dp数组
memset(dp, 0, sizeof(dp));
for (int j = 1; j <= n; j++) {
dp[n][j] = triangle[n][j];//先把最底一行放入dp中
}
// 动态规划求解最大路径和
for (int i = n - 1; i >= 1; i--) {
for (int j = 1; j <= i; j++) {
dp[i][j] = max(dp[i+1][j], dp[i+1][j+1]) + triangle[i][j];
}
}
// 输出最大路径和
cout << dp[1][1] << endl;
return 0;
}
图解: