South Central USA 2002 解题报告
A . The Hardest Problem Ever
PKU 1298 http://poj.org/problem?id=1298
题意:解码题,按照如下对应关系解码:
密文 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
原文 V W X Y Z A B C D E F G H I J K L M N O P Q R S T U
题解:简单题。
B. Polar Explorer
PKU 1299 http://poj.org/problem?id=1299
题意:给定圆的半径X,求圆周上两个点A和B的距离,其中圆心角AOB的角度为Z(0 <= Z <= 360)。
题解:核心是Z如果大于180,则Z = 360 - Z,即走劣弧。而且题目求的是来回一次,所以计算的时候弧长要乘2。
C. Door Man
PKU 1300 http://poj.org/problem?id=1300
题意:给定一些边和起点s,求能否找到一条从s到0的通路,并且要求访问所有的边。
题解:欧拉回路可行解判定。
首先利用flood fill从s遍历全图,如果0点没有被访问到则必定不存在;然后判断度数不为0的点是否有未被访问到的,如果有,说明图不连通,也必定不存在解;最后统计度数为奇数的点的个数P,以及具体的点:
1) P = 0,则必定有解;
2) P > 2,则无解;
3) P =2, 那么有解的前提是两个奇度数点中一个是s,另一个是0;否则无解。
D . The Umbrella Problem 2054
PKU 1301 http://poj.org/problem?id=1301
题意:给定一个10X10的地图,玩家从第一行的某一个点出发,每一步行编号+1,列编号增量有三种选择(-1, 0, 1),图中标记为S(laser gun)的点不能走,并且S的点会发出镭射光,第0秒朝上发射,第1秒朝右,第2秒朝下,第3秒朝左,循环往复,发射长度一直到地图边缘。问能否走到最后一行标记为G(grass)的地方。
题解:广搜。
hash[4][R][C]表示状态,每走一步,利用步数 mod 4计算出镭射光的方向,然后将所有的镭射光可达区域全部标记出来,未标记的点为可达点,枚举三个方向进行搜索。
E. Blue Gene, Jr.
PKU 1302 http://poj.org/problem?id=1302
题意:一个长度为N(N <= 20)的病毒基因串A[1...N]进行变异,变异过程从左往右,分情况讨论:
1) 如果第i个字符是 A-Z,则它将变异成数字n mod 10,n表示A[i+1...N]中变异基因的数目;
2) 如果第i个字符是 1-9,则它变异成A[i] - 1,并且如果第p (p = i + A[i])个基因存在的话,从第p个基因开始变异;否则从第i+1个基因开始变异;
题解:题意理解后就是个水题了,递归求解。
F . Byte Me!
PKU 1303 http://poj.org/problem?id=1303
题意:二进制二十一点(二进制黑杰克)是由两种牌组成的游戏,一种称为bytes(一个8比特的序列表示0-255之间的数),一种称为nibbles((一个4比特的序列表示0-15之间的数),游戏玩法如下:
1) 游戏的目标是获得尽量接近510分,并且不能超过它;
2) 每个玩家有两张牌,一张面朝上,一张面朝下(庄家不知道是什么牌);
3) 每个玩家有四次叫牌机会,可以叫bytes,也可以叫nibbles,但是如果分数超过510则不能再叫牌;
4) 所有的叫牌都是面朝上的;
5) 如果玩家分数超过510,立即判为输;
5) 庄家最后一个叫牌;
7) 平局的情况庄家胜(如果所有人都超过510分,庄家还是赢的);
庄家的规则如下:
1) 当看到自己和其他人面朝上的牌,判断已经必胜时不要再叫牌了;
2) 如果总分小于382时 需要叫一次byte牌;
3) 如果总分小于等于500时 需要叫一次nibble牌;
还有两个隐藏规则:
1) 你是庄家;
2) 每个非庄家的玩家面朝下的牌是11111111(但是庄家不知道),面朝上的牌给定;
3) 非庄家不会叫牌(因为他们比较笨);
给定庄家的牌和其他玩家面朝上的牌,以及牌堆中的bytes牌和nibble牌,求庄家的四次叫牌能否获胜;
题解:题目说了一大堆,最后非庄家的玩家都不会叫牌,o(╯□╰)o...所以只要根据庄家的规则进行叫牌,然后判断是否能够胜出即可;
因为其他人都不叫牌,每个人都有两张牌,所以其他人的总分不可能超过510分,所以,如果庄家叫牌超过510分直接被判为负。
每次叫牌前先判断所有玩家的朝上的卡片分数加上255和庄家当前得分进行比较,如果有一个玩家分数大于庄家分数,则庄家按照382和500这两个区间进行叫牌。
四次叫牌结束,如果所有玩家分数都小于等于庄家分数,则判断庄家分数是否大于510,如果是,输出Bust!,否则输出Win!;如果小于某个玩家的分数,那么输出Lose!。
G . World's Worst Bus Schedule
PKU 1304 http://poj.org/problem?id=1304
题意:公交车站有N(N <= 20)辆车,每辆车的发车时间间隔为a1 a2 a3 a4... a1 a2 a3 a4... a1 a2 a3 a4...,循环发车,问某人在T时刻赶到公交车站,最少需要等待多少时间能够乘上公交车。
题解:对于每辆公交车,设它的所有时间间隔之和为S,令T' = T mod S,然后枚举所有的发车间隔,前i个发车间隔a[i]之和减去T'中的最小正值就是等这辆公交车需要的时间,取所有公交车的最小时间就是所求。