首页 > 其他 > 详细

数字三角形

时间:2016-01-16 22:34:24      阅读:192      评论:0      收藏:0      [点我收藏+]
技术分享
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cstring>
 5 using namespace std;
 6 
 7 int s[100][100];
 8 int dp[100][100];
 9 int max(int a,int b)
10 {
11     if(a>b)
12     return a;
13     else 
14     return b;
15 }
16 int main()
17 {
18     int n,i,j;
19     while(~scanf("%d",&n))
20     {
21         memset(s,0,sizeof(s));
22         for(int i=1;i<=n;i++)
23         {
24             for(int j=1;j<=i;j++)
25                 scanf("%d",&s[i][j]);
26         }
27         for(j=1;j<=n;j++)    dp[n][j]=s[n][j];
28         for(i=n-1;i>=1;i--)
29         {
30             for(j=1;j<=i;j++)
31             dp[i][j]=s[i][j] + max(dp[i+1][j],dp[i+1][j+1]);
32         }
33         printf("%d\n",dp[1][1]);
34     }
35 }
View Code

动态规划 满足 最优子结构,以及消除重复的节点。

 

1. 递归 

2.递推

3.记忆化搜索

数字三角形

原文:http://www.cnblogs.com/WDKER/p/5136477.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!