用python怎样实现比较扑克牌大小的功能?
Admin 2021-11-24 群英技术资讯 2171 次浏览
之前我们了解了用python实现扑克游戏中判断牌型的功能,那么游戏的下一步是对扑克牌比较大小,那么这个效果要如何实现呢?接下来我们继续尝试用Python来实现比较扑克牌大小。
接上一篇的文章
players=deal_cards(2,5) Values=sort_values(players) CArdtype=result_card_type(players) -------------------------------------- '''通过以上三行代码就可以得到牌值和牌型了'''
知道了牌型牌值,就是进行比较了,加入自己玩的话,肯定是先比较牌型,牌型相同在比较大小,简单来说就是这样,代码实现也是这样
def compare_value(player_fir, play_sec, card_type_fir, card_type_sec):
if card_type_fir < card_type_sec:
return 1 #first<second
elif card_type_fir > card_type_sec:
return -1 #first>second
elif card_type_fir == card_type_sec: #牌型相等 比较大小
if card_type_fir in [9, 5, 4, 1, 0]: #高牌、顺子、同花、同花顺、皇家同花顺 直接比大小
for i in range(5):
if player_fir[i] > play_sec[i]:
return 1
elif player_fir[i] < play_sec[i]:
return -1
elif card_type_fir in [2, 3, 6]: #四条、葫芦、三条 比较中间的呢个牌值
if player_fir[2] > play_sec[2]:
return 1
elif player_fir[2] < play_sec[2]:
return -1
else :#相等
for i in range(5):
if player_fir[i] > play_sec[i]:
return 1
elif player_fir[i] < play_sec[i]:
return -1
elif card_type_fir == 7: #两对
if player_fir[1] > play_sec[1]:
return 1
elif player_fir[1] < play_sec[1]:
return -1
else:
if player_fir[3] > play_sec[3]:
return 1
elif player_fir[3] < play_sec[3]:
return -1
else:
for i in range(5):
if player_fir[i] > play_sec[i]:
return 1
elif player_fir[i] < play_sec[i]:
return -1
elif card_type_fir == 8: #一对 先找到对子的位置,比较大小
d1, d2 = 0, 0
for i in range(4):
if player_fir[i] == player_fir[i + 1]:
d1 = player_fir[i]
if play_sec[i] == play_sec[i + 1]:
d2 = play_sec[i]
if d1 > d2:
return 1
elif d1 < d2:
return -1
elif d1 == d2:
for i in range(5):
if player_fir[i] > play_sec[i]:
return 1
if player_fir[i] < play_sec[i]:
return -1
return 0
以上代码为比较大小的核心代码
注意:上面这个函数比较的是两个玩家,比较对各玩家就得需要几个循环了,这部分没有绝对的答案,也很简单,上面也有提到,可自行编写!
整体思想就是:
先比较牌型,小则返回-1,大则返回1
牌型相等的话
这里把高牌、顺子、同花、同花顺、皇家同花顺归为一类
依据就是这几类牌型没有特别之处,只需要比较大小就可,不像对子似的,先比较对子的大小,对子相等在比较五张牌大小
然后把四条、葫芦、三条归为一类,这三类的一个共同特征是中间的牌,一定有和它的值一样大小的牌
无论是四条、葫芦、三条,不理解的话可以画一下,一眼就可以看出来,这类的思想就是,先比较中间牌值的大小,小返回-1,大返回1,相等则比较五张牌的大小,小则返回-1,大返回1
两队单独归为一类,这里尼就得感谢室友了,不懂得可看图,附1
一对也单独归为一类,这类的思想就是先找到对子的位置,比较对子的大小,小则返回-1,大则返回1,相等则比较五张牌的大小,小则返回-1,大则返回1
有一种特殊的情况,那就是牌型一样,牌值也一样,这种概率,太低了,也是有可能出现的,小编就暂时不考虑把玩家相等的情况写出来了,起始也使用了一个数组存储,只是后面没有翻译
关于Python来实现比较扑克牌大小的内容就介绍到这,本文代码仅供参考,感兴趣的朋友可以了解看看,希望能对大家学习python有帮助,想要了解更多大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在模版中,有时候需要对一些数据进行处理以后才能使用。一般在Python中我们是通过函数的形式来完成的。而在模版中,则是通过过滤器来实现的。过滤器使用的是|来使用。
Bagging算法(Bootstrap aggregating,引导聚集算法),又称装袋算法,是机器学习领域的一种团体学习算法。最初由Leo Breiman于1996年提出。Bagging算法可与其他分类、回归算法结合,提高其准确率、稳定性的同时,通过降低结果的方差,避免过拟合的发生
有的时候需要用python处理二进制数据,比如,存取文件,socket操作时 这时候,可以使用python的struct模块来完成 可以用 struct来处理c语
验证码作为一种自然人的机器人的判别工具,被广泛的用于各种防止程序做自动化的场景中。传统的字符型验证安全性已经名存实亡的情况下,各种新型的验证码如雨后春笋般涌现,今天给大家分享一篇Python实现滑块验证码
通常,当我们需要对对象的敏感属性或者不希望外部直接访问的属性进行私有化,但是某些时候我们又需要对这些私有属性进行修改,该怎么处理呢,感兴趣的可以了解一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008