Python扑克牌的顺子

本文阅读 1 分钟
首页 Python笔记 正文

先置换特殊字符AJQK为数字,排序,然后求出大小王即0的个数,然后求出除去0之外的,数组间的数字间隔(求间隔的时候记得减去1,比如4和5的间隔为5-4-1,表示4和5是连续的数字),同时求间隔的时候需要鉴别是否出现对。最后比较0的个数和间隔的大小即可。

  1. '''
  2. 随机从扑克牌中抽出了5张牌,判断是不是顺子,
  3. 决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。
  4. '''
  5. # -*- coding:utf-8 -*-
  6. class Solution:
  7. def IsContinuous(self, numbers):
  8. if numbers == None or len(numbers) <= 0:
  9. return False
  10. # 把A、J、Q、K转化一下
  11. transDict = {'A': 1, 'J': 11, 'Q': 12, 'K': 13}
  12. for i in range(len(numbers)):
  13. if numbers[i] in transDict.keys():
  14. numbers[i] = transDict[numbers[i]]
  15. numbers = sorted(numbers)
  16. numberOfzero = 0
  17. numberOfGap = 0
  18. # 统计0的个数
  19. i = 0
  20. while i < len(numbers) and numbers[i] == 0:
  21. numberOfzero += 1
  22. i += 1
  23. # 统计间隔的数目
  24. small = numberOfzero
  25. big = small + 1
  26. while big < len(numbers):
  27. # 出现对子, 不可能是顺子
  28. if numbers[small] == numbers[big]:
  29. return False
  30. numberOfGap += numbers[big] - numbers[small] - 1
  31. small = big
  32. big += 1
  33. return False if numberOfGap > numberOfzero else True
  34. test = ['A', 3, 2, 5, 0]
  35. test2 = [0, 3, 1, 6, 4]
  36. s = Solution()
  37. print(s.IsContinuous(test2))
解压密码: detechn或detechn.com

免责声明

本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。

本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。

本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。

Python n个骰子的点数
« 上一篇 01-21
Python圆圈中剩下的数字
下一篇 » 01-21

发表评论

惪特博客
  • 文章总数:
    18497 篇
  • 评论总数:
    53306 条
  • 标签总数:
    8873 个
  • 总浏览量:
    22529629 次
  • 最后更新:
    3小时前

最多点赞

随便看看

标签TAG