hihocoder#1037之数字三角形

问题描述

小Hi和小Ho在经历了螃蟹先生的任务之后被奖励了一次出国旅游的机会,

于是他们来到了大洋彼岸的美国。美国人民的生活非常有意思,经常会有形形色色

的活动举办,这不,小Hi和小Ho刚刚下飞机,就赶上了当地的迷宫节活动。

迷宫节里展览出来的迷宫都特别的有意思,但是小Ho却相中了一个其实并不怎么像

迷宫的迷宫——因为这个迷宫的奖励非常丰富~

于是小Ho找到了小Hi,让小Hi帮助他获取尽可能多的奖品。

小Ho选择的迷宫是一个被称为“数字三角形”的n(n不超过200)层迷宫,

这个迷宫的第i层有i个房间,分别编号为1..i。除去最后一层的房间,

每一个房间都会有一些通往下一层的房间的楼梯,用符号来表示的话,

就是从第i层的编号为j的房间出发会有两条路,一条通向第i+1层的编号为j的房间,

另一条会通向第i+1层的编号为j+1的房间,而最后一层的所有房间都只有一条离开

迷宫的道路。这样的道路都是单向的,也就是说当沿着这些道路前往下一层的房间或者

离开迷宫之后,小Ho没有办法再次回到这个房间。迷宫里同时只会有一个参与者,

而在每个参与者进入这个迷宫的时候,每个房间里都会生成一定数量的奖券,

这些奖券可以在通过迷宫之后兑换各种奖品。小Ho的起点在第1层的编号为1的房间,

现在小Ho悄悄向其他参与者弄清楚了每个房间里的奖券数量,希望小Hi帮他计算出

他最多能获得多少奖券。

提示一:盲目贪心不可取,搜索计算太耗时

提示二:记忆深搜逞神威,宽度优先解难题

提示三:总结归纳提公式,减少冗余是真理

输入

每个测试点(输入文件)有且仅有一组测试数据。

每组测试数据的第一行为一个正整数n,表示这个迷宫的层数。

接下来的n行描述这个迷宫中每个房间的奖券数,其中第i行的第j个数代表着

迷宫第i层的编号为j的房间中的奖券数量。

测试数据保证,有100%的数据满足n不超过100

对于100%的数据,迷宫的层数n不超过100

对于100%的数据,每个房间中的奖券数不超过1000

对于50%的数据,迷宫的层数不超过15(小Ho表示2^15才3万多呢,也就是说……)

对于10%的数据,迷宫的层数不超过1(小Hi很好奇你的边界情况处理的如何?~)

对于10%的数据,迷宫的构造满足:对于90%以上的结点,左边道路通向的房间中的

奖券数比右边道路通向的房间中的奖券数要多。

对于10%的数据,迷宫的构造满足:对于90%以上的结点,左边道路通向的房间中的

奖券数比右边道路通向的房间中的奖券数要少。

输出

对于每组测试数据,输出一个整数Ans,表示小Ho可以获得的最多奖券数。

样例输入
5
2
6 4
1 2 8
4 0 9 6
6 5 5 3 6
样例输出
28

  
  
#include
     
     
      
      
#include
      
      
       
       

#define M 111

int n, a[M][M], best[M][M], max = 0;

void dfs(int r, int c, int sum)
{
	if(r == n)
	{
		max = max > sum ? max : sum;//走到最后一层与历史最优比较
		return;
	}	
	int i = r;
	for(int j = c; j <= i; j++)
	{
		if(j - c < 2)
		{
			if(best[i][j] < sum + a[i][j])//剪枝,如果在该处的历史最优值不小于当前,该处以下结点没有搜索必要
			{
				best[i][j] = sum + a[i][j];//更新走到该处能获得的最多奖券数
				dfs(i + 1, j, sum + a[i][j]);
			}
		}
		else
			return;
	}	
}

int main(void)
{
	int i, j;
	scanf("%d", &n);
	for(i = 0; i < n; i++)
		for(j = 0; j <= i; j++)
			scanf("%d", &a[i][j]);
	dfs(0, 0, 0);
	printf("%d\n", max);
	//system("pause");
}

      
      
     
     
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值