简单版四人扑克牌(python)

题目:
设计一个简单的四人制扑克牌游戏,能够完成以下功能:
1. 洗牌
2. 发牌
3.自定义规则,在每轮单张出牌时,判定赢家
4.自定义规则,判定最终的赢家
规则简化版:
仅能出单张牌,且出牌时,每个人出的是自己手中牌中刚好能压过上家的最小牌,最先出完的为赢家

import random
from random import choice
flower = ['\u2660','\u2663','\u2665','\u2666']
pai = ['3','4','5','6','7','8','9','10','J','Q','K','A','2']
list = []
list0 = []#储存发的牌
list1 = []
list2 = []
list3 = []
value = []
value0 = []#储存牌代表的值
value1 = []
value2 = []
value3 = []
l00 = []#储存进行升序排序后的牌
l11 = []
l22 = []
l33 = []
for i in flower:
    for j in pai:
        list.append(i+j)
for i in range(4):
    for j in range(13):
        value.append(j)
d = dict(zip(list,value))
for i in range(13):
    for j in range(4):
        if(j == 0):
            k = choice(list)#随机选牌
            for x in range(len(list)):
                if(k == list[x]):#和链表的牌进行匹配,删掉对应项
                    value0.append(d[k])
                    list.pop(x)
                    break
            list0.append(k)
        if(j == 1):
            k = choice(list)
            for x in range(len(list)):
                if (k == list[x]):
                    value1.append(d[k])
                    list.pop(x)
                    break
            list1.append(k)
        if (j == 2):
            k = choice(list)
            for x in range(len(list)):
                if (k == list[x]):
                    value2.append(d[k])
                    list.pop(x)
                    break
            list2.append(k)
        if (j == 3):
            k = choice(list)
            for x in range(len(list)):
                if (k == list[x]):
                    value3.append(d[k])
                    list.pop(x)
                    break
            list3.append(k)
d0 = dict(zip(list0,value0))#将每个人的牌转换为字典形式
d1 = dict(zip(list1,value1))
d2 = dict(zip(list2,value2))
d3 = dict(zip(list3,value3))
l0 = sorted(d0.values())#对牌所代表的数字进行排序
l1 = sorted(d1.values())
l2 = sorted(d2.values())
l3 = sorted(d3.values())
#对发给每个人的牌进行排序
for i in range(len(l0)):
    for j in list0:
        if(l0[i] == d0[j]):
            l00.append(j)
            break
for i in range(len(l1)):
    for j in list1:
        if(l1[i] == d1[j]):
            l11.append(j)
            break
for i in range(len(l2)):
    for j in list2:
        if(l2[i] == d2[j]):
            l22.append(j)
            break
for i in range(len(l0)):
    for j in list3:
        if(l3[i] == d3[j]):
            l33.append(j)
            break
# y = choice(['0','1','2','3'])
print("第一个人的牌:",l00)
print("第二个人的牌:",l11)
print("第三个人的牌:",l22)
print("第四个人的牌:",l33)
y = random.randint(0,3)
if (y == 0):
    y = y + 1
    n = l0[0]
    l0.pop(0)
elif (y == 1):
    y = y + 1
    n = l1[0]
    l1.pop(0)
elif (y == 2):
    y = y + 1
    n = l2[0]
    l2.pop(0)
elif (y == 3):
    y = 0
    n = l3[0]
    l3.pop(0)
for i in range(13):
    if(y == 0):
        for j in range(len(l0)):
            if(l0[j] > n):
                n = l0[j]
                l0.pop(j)
                if(len(l0) != 0 and n >= l1[len(l1)-1] and n >= l2[len(l2)-1] and n >= l3[len(l3)-1]):#判断是否当前牌中最大牌,若是,则该此人继续出牌
                    n = l0[0]
                    l0.pop(0)
                break
        y = y + 1
    if (len(l0) == 0):
        print("赢家:第一个人")
        break
    if(y == 1):
        for j in range(len(l1)):
            if(l1[j] > n):
                n = l1[j]
                l1.pop(j)
                if (len(l1) != 0 and n >= l0[len(l0) - 1] and n >= l2[len(l2) - 1] and n >= l3[len(l3) - 1]):
                    n = l1[0]
                    l1.pop(0)
                break
        y = y + 1
    if (len(l1) == 0):
        print("赢家:第二个人")
        break
    if(y == 2):
        for j in range(len(l2)):
            if(l2[j] > n):
                n = l2[j]
                l2.pop(j)
                if (len(l2) != 0 and n >= l0[len(l0) - 1] and n >= l1[len(l1) - 1] and n >= l3[len(l3) - 1]):
                    n = l2[0]
                    l2.pop(0)
                break
        y = y + 1
    if (len(l2) == 0):
        print("赢家:第三个人")
        break
    if (y == 3):
        for j in range(len(l3)):
            if (l3[j] > n):
                n = l3[j]
                l3.pop(j)
                if (len(l3) != 0 and n >= l0[len(l0) - 1] and n >= l1[len(l1) - 1] and n >= l2[len(l2) - 1]):
                    n = l3[0]
                    l3.pop(0)
                break
        y = 0
    if (len(l3) == 0):
        print("赢家:第四个人")
        break
#将剩余牌从键值转化成牌
if(len(l0) != 0):
    for i in range(len(l0)):
        for j in list0:
            if(l0[i] == d0[j]):
                l0[i] = j
                break
if(len(l1) != 0):
    for i in range(len(l1)):
        for j in list1:
            if(l1[i] == d1[j]):
                l1[i] = j
                break
if(len(l2) != 0):
    for i in range(len(l2)):
        for j in list2:
            if(l2[i] == d2[j]):
                l2[i] = j
                break
if(len(l3) != 0):
    for i in range(len(l3)):
        for j in list3:
            if(l3[i] == d3[j]):
                l3[i] = j
                break
print("第一个人的牌:",l0)
print("第二个人的牌:",l1)
print("第三个人的牌:",l2)
print("第四个人的牌:",l3)

你可能感兴趣的:(python)