给定一个由n行数字组成的数字三角形,设计一个算法,计算出从三角形的顶至底的一条路径,使该路径经过的数字总和最大。
测试用例: 5(行数)
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
输出: 30
#include<stdio.h>
#define n 5
int max(int a,int b)
{
return a>b?a:b;
}
int main()
{
int maxValue=0;
int a[n+1][n+1];
int i,j;
int map[n+1][n+1];
for(i=1;i<=n;i++)
for(j=1;j<=i;j++)
scanf("%d",&map[i][j]);
a[1][1]=map[1][1];
for(i=2;i<=n;i++)
{
for(j=1;j<=i;j++)
{
if(j==1)
a[i][j]=a[i-1][j]+map[i][j];
else if(j==i)
a[i][j]=a[i-1][j-1]+map[i][j];
else
a[i][j]=max(a[i-1][j-1],a[i-1][j])+map[i][j];
}
}
for(i=1;i<=n;i++)
if(a[n][i]>maxValue)
maxValue=a[n][i];
printf("%d",maxValue);
return 0;
}