SSL_1458【数字金字塔】


数字金字塔
题目

你和权权是一对很好很好的朋友。有一天,你们无聊得很,便上网冲浪,突然在一个叫做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;
}

原创:https://www.panoramacn.com
源码网提供WordPress源码,帝国CMS源码discuz源码,微信小程序,小说源码,杰奇源码,thinkphp源码,ecshop模板源码,微擎模板源码,dede源码,织梦源码等。

专业搭建小说网站,小说程序,杰奇系列,微信小说系列,app系列小说

SSL_1458【数字金字塔】

免责声明,若由于商用引起版权纠纷,一切责任均由使用者承担。

您必须遵守我们的协议,如果您下载了该资源行为将被视为对《免责声明》全部内容的认可-> 联系客服 投诉资源
www.panoramacn.com资源全部来自互联网收集,仅供用于学习和交流,请勿用于商业用途。如有侵权、不妥之处,请联系站长并出示版权证明以便删除。 敬请谅解! 侵权删帖/违法举报/投稿等事物联系邮箱:2640602276@qq.com
未经允许不得转载:书荒源码源码网每日更新网站源码模板! » SSL_1458【数字金字塔】
关注我们小说电影免费看
关注我们,获取更多的全网素材资源,有趣有料!
120000+人已关注
分享到:
赞(0) 打赏

评论抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

您的打赏就是我分享的动力!

支付宝扫一扫打赏

微信扫一扫打赏