Python编程基础题(26-家务分配问题)

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),不是字符串大小,所以需要从优先级串中取出点数之和,化为整型进行比较,如果直接比较字符串的大小,有可能会出问题。这是一个非常容易忽略的地方!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值