/*DP入门题
题意:输入一个三角形,从第一行到最后一行,
找出通过的路径上面的数字之和最大的和是多少?
思路:自下往上找,我是用DP[i][j]来记录下面的N-i+1行最大的和,理解啦思路感觉好经典的思想!
状态转移方程dp[i][j]=multiple[i][j]+max(dp[i+1][j],dp[i+1][j+1])
调试注意:开始的时候数组开小啦,所以以后开数组的时候稍微开大一点,还有就是memset的用法!
*/
#include <iostream>
#include <cstring>
#define MAX 1010
int multiple[MAX][MAX] ,dp[MAX][MAX];
using namespace std;
int main()
{
int N,i,j;
while (cin>> N)
{
memset(dp, 0, sizeof(dp));
for (i=1;i<=N;i++)
{
for (j=1;j<=i;j++)
cin>> multiple[i][j];
}
for (i=N;i>=1;i--)
{
for (j=1;j<=i;j++)
dp[i][j]=multiple[i][j]+max(dp[i+1][j],dp[i+1][j+1]);
}
cout << dp[1][1] << endl;
}
return 0;
}
DP入门题------ Number Triangles HOJ 1058
最新推荐文章于 2018-07-05 23:23:19 发布