郑厂长系列故事——逃离迷宫
题目:http://acm.hdu.edu.cn/showproblem.php?pid=4524
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 1247 Accepted Submission(s): 611
Problem Description
郑厂长没变
还是那个假厂长真码农
改变的是业余爱好
他现在不研究象棋,改玩游戏了!
最近,郑厂长爱上了逃离迷宫这个游戏,他日日夜夜的玩,就是想达到自己的目标:1000万,因为这个数字和他在腾讯的年收入一样多。
不过,在他跑到9999999时,游戏屏幕上突然出现了好多箱子,郑厂长必须要消除所有这些箱子才能继续玩游戏。这些箱子排成一行,每个箱子上都有个数字,每个数字代表这个箱子需要被点击的次数才会消失。每个箱子被点击时对应数字会减1,并且他右边箱子的数字也会同时减1,当箱子数字变成0,则其就就消失了。需要说明的是,如果右边没有箱子或者右边的箱子已经消失了,则无法操作当前的箱子(以上所说的“右边”只是指紧挨着的右边,隔开的不算)。
现在已知这些箱子的信息,请问郑厂长是否能成功消除所有的箱子然后继续达成他的千万梦想呢?
Input
输入首先包含一个正整数T,表示有T组测试样例;
每组样例有两行,第一行是一个整数n,代表有n个箱子;第二行有n个数字ai,代表每个箱子需要被点击的次数。
[Technical Specification]
T<=100
1 <= n <= 10 ^ 6
0 <= ai <= 10 ^ 9 (1 <= i <= n)
Output
对于每个样例,如果郑厂长能成功消除这些箱子成功逃脱,请输出"yeah~ I escaped ^_^",否则就输出"I will never go out T_T"。
Sample Input
2
2
2 2
2
1 2
Sample Output
yeah~ I escaped ^_^
I will never go out T_T
Source
2013腾讯编程马拉松初赛第四场(3月24日)
本来想做那道BFS逃离迷宫的,但搜索 逃离迷宫 搜索到这道题,再看看是出题人,于是就做一做了。
上篇那个Dating with girls也是,本来想做2,顺便也把1做了。
这道题,恩,类似于消除游戏,
n个方块排一行,点击任何一个,右相邻的方块与所点击方块内数字减一,任何方块内数字为0则消失。
方块消失后,若右方有方块,则向左对齐过去。
解题:
刚开始,我以为是只要所输入方块数字和为偶数则可以全部消除。
但是,后来做的时候发现有一种情况不能消除,
最大的数的大于剩余所有的数的和:2 4 8
这样肯定不能消除,虽然和为偶数。
后来发现,就是一直点击左面的方块就可以了。
然后模拟一下就可以了。
/*
Author:Tree
From: http://blog.csdn.net/lttree
郑厂长系列故事——逃离迷宫
hdu 4524
简单题
*/
#include <stdio.h>
int abs(int a)
{
return a<0?-a:a;
}
int main()
{
int n,t,i,temp,sum;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&sum);
for(i=1;i<n;++i)
{
scanf("%d",&temp);
sum=abs(sum-temp);
}
if(sum) printf("I will never go out T_T\n");
else printf("yeah~ I escaped ^_^\n");
}
return 0;
}