题解 | #扑克牌大小#

扑克牌大小

https://www.nowcoder.com/practice/d290db02bacc4c40965ac31d16b1c3eb

拿的解题区大神的代码,自己添加了注释后版本,应该是比较详细了

# 创建一个函数,判断手牌是不是炸弹(王炸 或者 4炸)
def Bombs(pai):
    if 'joker' in pai and 'JOKER' in pai:
        return True
    elif len(pai) == 4:
        return True 

while True:
    try:
        # 按照‘-’分为两边手牌
        old = input().split('-')
        # 去掉两边手牌中的空格,得到
        a = old[0].split()
        b = old[1].split()
        # 创建一个用于判断牌面大小的字典
        dic = {'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9,'10':10,'J':11,'Q':12,'K':13,'A':14,'2':15,'joker':16,'JOKER':17}

        # 先判断有炸弹的情况
        # 有炸弹的情况分两种:
        #   一种是双方都是炸弹
        #   一种是只有一方有炸弹

        # a和b中都有炸弹,
        if Bombs(a) and Bombs(b):
            # 则需要去字典中比较炸弹牌的大小,即比较牌中第一个元素的大小
            if dic[a[0]] > dic[b[0]]:
                print(old[0])
            else:
                print(old[1])
        # a和b中只有一个炸弹
        elif Bombs(a):
            print(old[0])
        elif Bombs(b):
            print(old[1])

        # 在判断没有炸弹存在的情况
        # 没有炸弹存在先要看这两个牌的长度是否相等
        #   如果不等,那就是错误的情况,输出ERROR
        #   如果相等,那就要进入字典判断那个牌面大
        elif len(a) == len(b):
            if dic[a[0]] > dic[b[0]]:
                print(old[0])
            else:
                print(old[1])
        else:
            print('ERROR')

    except:
        break

全部评论

相关推荐

03-26 13:04
已编辑
电子科技大学 算法工程师
xiaowl:你这个简历“条目上”都比较有深度性,但是实际上面试官又没法很好的评估你是怎么达到很多看上去很厉害的结果的。要避免一些看上去很厉害的包装,比如高效的内存复用策略的表达,如果仅是简单的一些内存共享机制,而且面试上也没有深挖的空间,就不要这样表达。比如,工程化模式本质上可能就是定义了一些abstract class,那也就没特别多值得讲的内容。建议简历上应该侧重那些你花了大量时间和精力解决、研究的问题,不要过分追求“丰富”,而是关注在技术深入度、问题解决能力的表现上。
没有实习经历,还有机会进...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务