题目
用54张扑克牌,先洗牌,
再按斗地主的发牌方式把牌发给三个玩家,多的3张牌给第一个玩家(地主),
最后把每个玩家手上的牌显示出来。
思路
首先;我们需要一个列表来保存我的的牌,然后是就是三个玩家,做一个循环,每轮我们每人发几张牌做多少次完成,最后三张牌给地主。最后显示三个玩家的牌就可以了。
代码
import random
suites = ['♠︎', '♥︎', '♣︎', '♦︎']
faces = ['A', '2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K']
# 列表生成式(推导式)
cards = [f'{suite}{face}' for suite in suites for face in faces]
# append - 向列表中追加元素
cards.append('小王')
cards.append('大王')
# 随机乱序(洗牌)
random.shuffle(cards)
# 嵌套列表(列表中的元素又是列表)
players = [[] for _ in range(3)]
for _ in range(17):
for player in players:
# pop - 删除元素(默认删除最后一个元素)
player.append(cards.pop())
# extend - 将一个列表的元素合并到另一个列表中
players[0].extend(cards)
for player in players:
# sort - 对列表中的元素进行排序
player.sort(key=lambda x: x[1:])
for card in player:
print(card, end=' ')
print()