来诈金花嘛?Python实现的那种

科技   科技   2024-10-06 17:40   广东  
点击上方“Python爬虫与数据挖掘”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

寒雨连江夜入吴,平明送客楚山孤。

大家好,我是Python进阶者。

前言

《诈金花》又叫三张牌,是在全国广泛流传的一种民间多人纸牌游戏。比如JJ比赛中的诈金花(赢三张),具有独特的比牌规则。游戏过程中需要考验玩家的胆略和智慧。--《百度百科》 前几天在Python交流群里边,有个叫【^-^】的粉丝分享了一道扑克牌诈金花的题目,要求用Python实现,题目如下:

自己写一个程序,实现发牌、比大小判断输赢。

#### 游戏规则:

一付扑克牌,去掉大小王,每个玩家发3张牌,最后比大小,看谁赢。

有以下几种牌:

豹子:三张一样的牌,如3张6.

顺金:又称同花顺,即3张同样花色的顺子, 如红桃 5、6、7

顺子:又称拖拉机,花色不同,但是顺子,如红桃5、方片6、黑桃7,组成的顺子

对子:2张牌一样

单张:单张最大的是A

这几种牌的大小顺序为, **豹子>顺金>顺子>对子>单张**



#### 需程序实现的点:

1. 先生成一付完整的扑克牌

2. 给5个玩家随机发牌

3. 统一开牌,比大小,输出赢家是谁

一、思路

针对这个问题,首先需要构造一副扑克牌,根据扑克牌的属性特征,进行不断的拆解,然后构造玩家用户,这里经常会用到字典和列表来存储信息,屡试不爽。

二、解决方案

针对该问题,粉丝【^-^】给出了解决方法,直接上代码如下:

# -*- coding: utf-8 -*-
import random


puke = []  # 存储扑克牌
num_list = ['2''3''4''5''6''7''8''9''10''J''Q''K''A']
hua_list = ['梅花''红桃''黑桃''方块']
sort_dic = {'2': 0, '3': 1, '4': 2, '5': 3, '6': 4, '7': 5, '8': 6, '9': 7, '10': 8, 'J': 9, 'Q': 10, 'K': 11, 'A': 12,
      '对子': 15, '顺子': 30, '顺金': 60, '豹子': 100}
count_new_list = []  # 存储玩家分数和排序后排名
count_dic = {}  # 存储玩家分数
# 准备52张扑克
for hua in hua_list:
  for num in num_list:
    a = hua + num
    puke.append(a)
player_dic = {'玩家1': [], '玩家2': [], '玩家3': [], '玩家4': [], '玩家5': []}
# 随机给五个玩家发牌
# print(len(puke))
for key, value in player_dic.items():
   for i in range(3):
        plate = random.sample(puke, 3)
        player_dic[key] = plate
        for i in plate:
            puke.remove(i)
print(player_dic)


# 获取玩家的牌型
def paixing(list1):
  num = []
  huase = []
  for i in list1:
    a = i[2:]
    b = i[:2]
    num.append(a)
    huase.append(b)
  return num, huase

# sort_dic = {'2': 0, '3': 1, '4': 2, '5': 3, '6': 4}
# 对数字的牌型进行排序
def sort(num):
  new_num = []
  sort_list2 = []
  list1 = []
  for i in num:
    new_num.append(sort_dic[i])
  new_num = sorted(new_num)  # 排序后是[2, 4, 7]
  for new in new_num:
    sort_list2.append([k for k, v in sort_dic.items() if v == new])
  for m in sort_list2:
    for n in m:
      list1.append(n)
  return list1


# 对玩家的牌形统计分数
def count(num, huase):
  a = 0
  base_count = sort_dic[num[0]] + sort_dic[num[1]] + sort_dic[num[2]]
  if num[0] == num[1] and num[1] == num[2]:
    paixing = '豹子'
    a = base_count + sort_dic[paixing]

  elif (sort_dic[num[0]] + 1 == sort_dic[num[1]] and sort_dic[num[2]] - 1 == sort_dic[num[1]]) and (huase[0] == huase[
    1] and huase[1] == huase[2]):
    paixing = '顺金'
    a = base_count + sort_dic[paixing]

  elif (sort_dic[num[0]] + 1 == sort_dic[num[1]]) and (sort_dic[num[2]] - 1 == sort_dic[num[1]]) and (
      huase[0] != huase[
    1] or huase[1] != huase[2]):
    paixing = '顺子'
    a = base_count + sort_dic[paixing]

  elif (num[0] == num[1] and num[1] != num[2]) or (num[1] == num[2] and num[0] != num[1]) or (
      num[0] == num[2] and num[1] != num[0]):
    paixing = '对子'
    a = base_count + sort_dic[paixing]

  else:
    a = base_count
  return a


# 对存储玩家分数的字典进行排序
def compare(count_dic):
  d = list(zip(count_dic.values(), count_dic.keys()))
  return sorted(d, reverse=True)


for key, value in player_dic.items():
  num, huase = paixing(value)
  num = sort(num)
  count1 = count(num, huase)
  count_dic[key] = count1
  print(key + "的牌为:" + str(value))
  count_new_list = compare(count_dic)
# print(count_new_list)
print('最终排名:' + "\t" + count_new_list[0][1] + "第一名" + "\t" + count_new_list[1][1] + "第二名" + "\t" + count_new_list[2][
  1] + "第三名" + "\t" + count_new_list[3][1] + "第四名" + "\t" + count_new_list[4][1] + "第五名")

代码看上去确实挺多的,超过了100行,需要花点时间去读,不过涉及的知识点并不复杂,基本上有点Python基础,也可以理解。代码运行之后,可以看到效果如下:

不过后来我在读取这份代码的时候,发现中间有个地方写的着实有些冗余,稍微修改下,代码方面简洁一些,一些函数和变量命名加了一些对应的现实意义的单词,可读性强了一丢丢,代码如下:

# -*- coding: utf-8 -*-
import random


puke = []  # 存储扑克牌
num_list = ['2''3''4''5''6''7''8''9''10''J''Q''K''A']
hua_list = ['梅花''红桃''黑桃''方块']
sort_dic = {'2': 0, '3': 1, '4': 2, '5': 3, '6': 4, '7': 5, '8': 6, '9': 7, '10': 8, 'J': 9, 'Q': 10, 'K': 11, 'A': 12,
      '对子': 15, '顺子': 30, '顺金': 60, '豹子': 100}
count_new_list = []  # 存储玩家分数和排序后排名
count_dic = {}  # 存储玩家分数
# 准备52张扑克
for hua in hua_list:
  for num in num_list:
    a = hua + num
    puke.append(a)
player_dic = {'玩家1': [], '玩家2': [], '玩家3': [], '玩家4': [], '玩家5': []}
# 随机给五个玩家发牌
print(len(puke))
for key, value in player_dic.items():
   for i in range(3):
        plate = random.sample(puke, 3)
        player_dic[key] = plate
        for i in plate:
            puke.remove(i)
print(player_dic)


# 获取玩家的牌型
def paixing(list1):
  num = []
  huase = []
  for data in list1:
    huase_type = data[:2]
    pai_number = data[2:]
    num.append(pai_number)
    huase.append(huase_type)
  return num, huase


# 对玩家的牌形统计分数
def get_score(num, huase):
  base_count = sort_dic[num[0]] + sort_dic[num[1]] + sort_dic[num[2]]
  if num[0] == num[1] and num[1] == num[2]:
    paixing = '豹子'
    score = base_count + sort_dic[paixing]

  elif (sort_dic[num[0]] + 1 == sort_dic[num[1]] and sort_dic[num[2]] - 1 == sort_dic[num[1]]) and (huase[0] == huase[
    1] and huase[1] == huase[2]):
    paixing = '顺金'
    score = base_count + sort_dic[paixing]

  elif (sort_dic[num[0]] + 1 == sort_dic[num[1]]) and (sort_dic[num[2]] - 1 == sort_dic[num[1]]) and (
      huase[0] != huase[
    1] or huase[1] != huase[2]):
    paixing = '顺子'
    score = base_count + sort_dic[paixing]

  elif (num[0] == num[1] and num[1] != num[2]) or (num[1] == num[2] and num[0] != num[1]) or (
      num[0] == num[2] and num[1] != num[0]):
    paixing = '对子'
    score = base_count + sort_dic[paixing]

  else:
    score = base_count
  return score


if __name__ == '__main__':
  for key, value in player_dic.items():
    num, huase = paixing(value)
    # 对数字的牌型进行排序
    num = sorted(num)
    score = get_score(num, huase)
    count_dic[key] = score
    print(key + "的牌为:" + str(value))
    # 对存储玩家分数的字典进行排序
    count_new_list = sorted(zip(count_dic.values(), count_dic.keys()), reverse=True)
  print("最终排名:")
  for i in range(len(count_new_list)):
    print(count_new_list[i][1] + '\t', end='')

【金融大模型开发基础与实践】

金融大模型开发一本通

金融大模型开发实践指南:覆盖金融大模型开发全流程,

加速金融业智能化引领金融智能新时代。

关键点

1.系统性与实践性并重:覆盖金融大模型开发全流程,从理论到实践,即学即用。

2.深入金融领域核心:专注于金融大模型的开发与应用,涵盖金融时间序列分析、风险建模与管理、高频交易与算法交易、信用风险评估、资产定价等关键领域,帮助读者深入理解金融数据背后的逻辑与规律。

3.技术前沿与趋势引领:不仅介绍当前主流的金融大模型开发技术栈,还探讨了区块链与金融科技创新、未来金融智能化发展趋势等前沿话题,使读者能够紧跟行业步伐,把握未来发展方向。

内容简介

本书结合具体实例循序渐进地讲解了金融大模型开发的核心知识。

全书共12章,分别讲解了大模型基础、大模型开发技术栈、数据预处理与特征工程、金融时间序列分析、金融风险建模与管理、高频交易与算法交易、信用风险评估、资产定价与交易策略优化、金融市场情绪分析、银行应用大模型开发实战、区块链与金融科技创新和未来金融智能化发展趋势。本书内容丰富全面,是学习金融大模型开发的优秀教程。

本书既适合已经掌握Python基础开发的初学者学习使用,也适合想进一步学习大模型开发、模型优化、模型应用和模型架构的读者阅读。本书不仅可以作为证券、保险、银行等行业从业者的参考书,还可以作为大专院校和培训学校的专业性教材。

作者简介

陈强,中国海洋大学计算机博士,资深软件开发工程师和架构师,现在就职于牛津大学(苏州)科技有限公司研发中心,从事于量化金融、衍生品(期货期权)交易策略、金融建模和金融数据分析的架构和开发工作。曾经在谷歌市场中发布过多款著名的应用等软件,这些应用软件在谷歌市场上取得了骄人的销售战绩。另外,还精通C#、Java、C++和C语言等主流编程语言,在国内主流期刊中发表过多篇计算机通信领域的著名论文。

三、总结

我是Python进阶者。本文实际生活中的诈金花游戏,基于Python编程,使用Python基础知识中的列表、字典、函数等,实现了在线诈金花的过程。

最后感谢粉丝【^-^】的分享。这个问题肯定小编相信肯定还有其他的方法的,也欢迎大家在评论区谏言。

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

------------------- End -------------------

往期精彩文章推荐:

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【入群

万水千山总是情,点个【在看】行不行

/今日留言主题/

随便说一两句吧~~

Python爬虫与数据挖掘
人生苦短,我用Python。该公众号专注于分享Python网络爬虫、数据挖掘、数据分析、数据处理、数据可视化、自动化测试、运维、大数据、人工智能、云计算、机器学习等工具资源、热点资讯、相关技术文章、学习视频和学习资料等,期待您的加入~~~
 最新文章