SSL_1458【数字金字塔】

   日期:2020-08-20     浏览:92    评论:0    
核心提示:数字金字塔题目你和权权是一对很好很好的朋友。有一天,你们无聊得很,便上网冲浪,突然在一个叫做USACO的网中找到了一个游戏:《数字金子塔》。游戏规则是这样的:求一个数字金字塔中从最高点开始在底部任意处结束的路径经过数字的和的最大,其中的每一步可以走到下方的点也可以到达右下方的点。例如在下面的例子中,从7 — 3 — 8 — 7 –- 5的路径产生了最大和:30。73 88 1 02 7 4 44 5 2 6 5你们便约定了谁能计算出最后的值便是赢者。你仰天(天花板)长叹:我能成为赢者吗,要知

数字金字塔

题目

你和权权是一对很好很好的朋友。有一天,你们无聊得很,便上网冲浪,突然在一个叫做USACO的网中找到了一个游戏:《数字金子塔》。游戏规则是这样的:求一个数字金字塔中从最高点开始在底部任意处结束的路径经过数字的和的最大,其中的每一步可以走到下方的点也可以到达右下方的点。例如在下面的例子中,从7 — 3 — 8 — 7 –- 5的路径产生了最大和:30。

7

3 8

8 1 0

2 7 4 4

4 5 2 6 5

你们便约定了谁能计算出最后的值便是赢者。你仰天(天花板)长叹:我能成为赢者吗,要知道权权可是很厉害的哦……

输入

第一行输入N(1<=N<=1000),表示数字金字塔行的数目。后面N输入这个数字金字塔,每个数字皆为整数(1<=x<=10000),每2个整数之间有1个空格。

输出

单独一行输出最后能得到的最大的和。

Sample Input

5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5

Sample Output

30

题意

我们要注意到题目数据最大是1000行,显然DFS暴搜会愉快超时,因此采取记忆化搜索。
保证每个点只处理一次,优化后A了。

代码

#include<iostream>
#include<cstdio>
using namespace std;
int n,a[1001][1001],b[1001][1001];
int dp(int x,int y)
{
 if(x>n)return 0;
 if(b[x][y]==0)b[x][y]=max(dp(x+1,y),dp(x+1,y+1))+a[x][y];
 return b[x][y];
}
int main()
{
 cin>>n;
 for(int i=1;i<=n;i++)
 {
  for(int j=1;j<=i;j++)scanf("%d",&a[i][j]);
 }
 cout<<dp(1,1);
 return 0;
}
 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服