1. 程式人生 > >華為2016校園招聘上機筆試題:撲克牌大小 [python]

華為2016校園招聘上機筆試題:撲克牌大小 [python]

'''
[程式設計題] 撲克牌大小
時間限制:10秒
空間限制:131072K
撲克牌遊戲大家應該都比較熟悉了,一副牌由54張組成,含3~A,2各4張,小王1張,大王1張。
牌面從小到大用如下字元和字串表示(其中,小寫joker表示小王,大寫JOKER表示大王):) 
3 4 5 6 7 8 9 10 J Q K A 2 joker JOKER 
輸入兩手牌,兩手牌之間用“-”連線,每手牌的每張牌以空格分隔,“-”兩邊沒有空格,如:4 4 4 4-joker JOKER
請比較兩手牌大小,輸出較大的牌,如果不存在比較關係則輸出ERROR


基本規則:
(1)輸入每手牌可能是個子,對子,順子(連續5張),三個,炸彈(四個)和對王中的一種,不存在其他情況,
由輸入保證兩手牌都是合法的,順子已經從小到大排列;
(2)除了炸彈和對王可以和所有牌比較之外,其他型別的牌只能跟相同型別的存在比較關係
(如,對子跟對子比較,三個跟三個比較),不考慮拆牌情況(如:將對子拆分成個子)
(3)大小規則跟大家平時瞭解的常見規則相同,個子,對子,三個比較牌面大小;順子比較最小牌大小;
炸彈大於前面所有的牌,炸彈之間比較牌面大小;對王是最大的牌;
(4)輸入的兩手牌不會出現相等的情況。


答案提示:
(1)除了炸彈和對王之外,其他必須同類型比較。
(2)輸入已經保證合法性,不用檢查輸入是否是合法的牌。
(3)輸入的順子已經經過從小到大排序,因此不用再排序了.


輸入描述:
輸入兩手牌,兩手牌之間用“-”連線,每手牌的每張牌以空格分隔,“-”兩邊沒有空格,如4 4 4 4-joker JOKER。




輸出描述:
輸出兩手牌中較大的那手,不含連線符,撲克牌順序不變,仍以空格隔開;如果不存在比較關係則輸出ERROR。


輸入例子1:
4 4 4 4-joker JOKER


輸出例子1:
joker JOKER
'''



'''
解題思路:仔細小心
   華為筆試的題目解題思路都很簡單,一眼就能望到頭,不需要太多思考,只要仔細小心的分析清楚每一種情況,
   就都能做出來
'''


'''
程式碼執行結果:
答案正確:恭喜!您提交的程式通過了所有的測試用例

'''

def judge_token(cs):
    length = len(cs)
    if length == 1:
        return 'single'
    elif length == 3:
        return 'triple'
    elif length == 4:
        return 'bomb'
    elif length == 5:
        return 'seq'
    elif length == 2:
        if cs == ['joker', 'JOKER']:
            return 'j-bomb'
        else:
            return 'double'

card_dict = {'3': 1, '4': 2, '5': 3, '6': 4, '7': 5, '8': 6, '9': 7, '10': 8, 'J': 9, 'Q': 10, 'K': 11,
             'A': 12, '2': 13, 'joker': 14, 'JOKER': 15}

while True:
    try:
        cards = input().split('-')
        cards_1 = cards[0].split()
        cards_2 = cards[1].split()
        cards_1_token = judge_token(cards_1)
        cards_2_token = judge_token(cards_2)
        if cards_1_token != 'bomb' and cards_1_token != 'j-bomb' and cards_2_token != 'bomb' and cards_2_token != 'j-bomb':
            if cards_1_token == cards_2_token:
                if card_dict[cards_1[0]] > card_dict[cards_2[0]]:
                    print(' '.join(cards_1))
                else:
                    print(' '.join(cards_2))
            else:
                print('ERROR')
        elif (cards_1_token == 'bomb' or cards_1_token == 'j-bomb') and (cards_2_token != 'bomb' and cards_2_token != 'j-bomb'):
            print(' '.join(cards_1))
        elif (cards_1_token != 'bomb' and cards_1_token != 'j-bomb') and (cards_2_token == 'bomb' or cards_2_token == 'j-bomb'):
            print(' '.join(cards_2))
        elif cards_1_token == 'bomb' and cards_2_token == 'j-bomb':
            print(' '.join(cards_2))
        elif cards_1_token == 'j-bomb' and cards_2_token == 'bomb':
            print(' '.join(cards_1))
        else:
            if card_dict[cards_1[0]] > card_dict[cards_2[0]]:
                print(' '.join(cards_1))
            else:
                print(' '.join(cards_2))
    except:
        break