数字三角形(题解)
数字三角形
题目描述
给定一个如下图所示的数字三角形,从顶部出发,在每一结点可以选择移动至其左下方的结点或移动至其右下方的结点,一直走到底层,要求找出一条路径,使路径上的数字的和最大。
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
输入格式
第一行包含整数 n
,表示数字三角形的层数
接下来 n
行,每行包含若干整数,其中第 i
行表示数字三角形第 i
层包含的整数。
输出格式
输出一个整数,表示最大的路径数字和。
样例 #1
样例输入 #1
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
样例输出 #1
30
提示
1 ≤ n ≤ 500
−10000 ≤ 三角形中的整数 ≤ 10000
思路:因为从顶部出发到底层的数字的和的最大值其实等于从底层走到顶层的数字的和的最大值
既然如此,我们就不妨求一下从底层走到顶层的数字的最大值
由于每一个数字都可以由左下角或右下角的数字走过来,因此,可得动态转移方程式a[i][j]+=max(a[i+1][j],a[i+1][j+1])
而最终a[1][1]中储存的就是从底层走到顶层的数字的和的最大值
上题解:
#include <iiostream>
using namespace std;
typedef long long ll;
const ll N=1e3+1e2;
ll n;
ll a[N][N];
ll ans;
int main()
{
cin>>n;
for(ll i=1;i<=n;i++)
{
for(ll j=1;j<=i;j++)
{
cin>>a[i][j];
}
}
for(ll i=n-1;i>=1;i--)//由下往上走
{
for(ll j=1;j<=i;j++)
{
a[i][j]+=max(a[i+1][j],a[i+1][j+1]);//动态转移方程式
}
}
cout<<a[1][1];
return 0;
}
完美结束!!!