Description
lcy和Ypop因为谁做家务的问题争执了起来,lcy每天辛辛苦苦上班,Ypop每天辛辛苦苦科研,其实这两个人都是大懒虫(其实lcy更懒),所以lcy和Ypop决定玩骰子游戏,
他们用三颗六面的骰子,游戏规则如下:
1.点数的优先级是1点最大,其次是6,5,4,3,2。
2.三个骰子点数相同,称为"豹子",豹子之间按点数优先级比较大小。
3.如果只有两个骰子点数相同,称为"对子",对子之间按点数优先级比较大小。
4.其他情况称为"点子",点子按点数和比较大小。
5.豹子比对子、点子大,对子比点子大,如果对子的点数优先级相同,就看剩余那个骰子的点数优先级。
现在给你lcy和Ypop投掷骰子的情况,判断一下胜负情况。
Input
第一行输入一个整数K,表示游戏的次数。 以后每两行表示一个样例,第一行是lcy骰子的点数。第二行是Ypop骰子的点数。
Output
如果是lcy赢,输出"lcy",如果是Bob赢,输出"Ypop",否则输出"Draw"。
Sample Input
3
1 1 1
6 6 6
2 1 2
4 5 4
4 5 6
6 5 4
Sample Output
lcy
Ypop
Draw
参考程序
def NumberPri(num):
if num==1:
return '6'
else:
return str(num-1)
def GetPriority(a,b,c):
if a==b and b==c:
#豹子
return 'C'+NumberPri(a)
elif a!=b and b!=c and a!=c :
#点子
return 'A'+str(a+b+c)
else:
#对子
if a==b and b!=c:
return 'B'+NumberPri(a)+NumberPri(c)
elif a==c and a!=b:
return 'B'+NumberPri(a)+NumberPri(b)
elif b==c and b!=a:
return 'B'+NumberPri(b)+NumberPri(a)
K=int(input())
for i in range(K):
a,b,c=map(int,input().split())
d,e,f=map(int,input().split())
lcy=GetPriority(a,b,c)
Bob=GetPriority(d,e,f)
if lcy[0]==Bob[0]=='A':
lcy=int(lcy[1:])
Bob=int(Bob[1:])
if lcy>Bob:
print("lcy")
elif lcy<Bob:
print("Ypop")
else:
print("Draw")
注意:
本题的思路就是把题目中关于“大小比较”的描述量化,即转换成字符串,然后通过字符串的比较来完成判定。“豹子”类型之间,“对子”类型之间以及不同类型之间都可以顺利比较。但是,当输入的两组数据都属于“点子”类型时,由于都是优先级都是“A”,且比较的是点数之和(点数之和可能大于10,如例如 6 5 4,对应优先级串为A15,2 3 4,对应优先级串A6),不是字符串大小,所以需要从优先级串中取出点数之和,化为整型进行比较,如果直接比较字符串的大小,有可能会出问题。这是一个非常容易忽略的地方!