麻将普通胡牌算法(带混)
最近在玩腾讯的麻将游戏,但是经常需要充值,于是就想自己实现一个简单的单机麻将游戏.第一个难点就是实现胡牌的判断.这里写一下心得.
术语
本文的胡牌是指手牌构成了3N+2的牌型,即一对做将,剩下的牌均为刻子(3张一样的牌)或者顺子(3张连续的牌比如234饼).
下面就是一个14张牌胡牌的例子:
122334饼23499条中中中
其中两张9条做将,三副顺子为123饼、234饼,234条,3个红中组成一副刻子.
我们要实现的函数只判断是否胡牌,但不计算胡牌的番数.
核心要点
我的思路参考了https://blog.csdn.net/weixin_33961829/article/details/88997328.
即首先选出做将的牌,然后看看剩余的牌是否成型.所谓成型,就是牌可以分成N组,每组3张,为顺子或者刻子.
如果允许牌里含有混(也叫癞子或者白搭),于是问题就可以转化为对一门麻将牌,求出还需要多少个混才能让他成型.显然如果所需的混数不超过已有的混数目,则说明原来的手牌是胡牌.
最少混的求法
下面看一些例子:
比如对顺子(比如 123饼) 或者刻子(比如3张3万),他们已经成型了,所需混子数为0.
如果是一对(比如两张7饼)或者二连(比如12万),隔连(46条),则至少需要再补一张牌才能成型,所以这三种情况都需要补一张混
对单牌,则需要补两张混才能成型.
由此就可以理解下面的一个求某门数牌最小补混数目的算法:
1.将数字牌按面值排序,并记录其数目.
比如九莲宝灯的胡牌11123456789999可以表达为
[3,1,1,1,1,1,1,1,4],即1万3张2到8万各1张,9万4张.
2.从第一张牌开始,每次进行如下处理:
(1)如果本牌的剩余数目不为0,执行(2),否则对下一张牌重新开始进行(1)的操作
(2) 如果本牌的剩余数目>=3,则将本牌的数目-3,即从牌中去掉一组刻子,然后回到(1),否则执行(3)
(3)判断本牌是否可以和后面的两张牌构成顺子,如果可以的话则将这3张牌的数目都减1,然后回到(1) .否则执行(4) 比如当前处理的牌为6万,然后7万和8万的数目都大于0,则把678的数目都减1,也就是去掉这副顺子,不需要补混.如果7万或者8万有一个数目为0,就要执行(4).再比如当前牌为8万,也要执行(4)
(4)判断本牌的数目是否>=2,是的话,即数目减2,然后混子数+1,再回到(1).这一步的目的是每个对子补一张混.如果当前牌无法构成对子,则执行(5)
(5)判断下一张牌的数目是否>0,是的话则本牌和下一张牌的数目都减1,然后混子数+1,再回到(1).这一步是给每个2连补一个混.如果构不成2连的话则继续执行(6)
(6)判断隔一张牌的数目是否>0.是的话则本牌和隔一张牌的数目都减1,然后混子数+1,再回到(1).这一步是给每组隔张补一个混.这一步是给每组隔张补一个混,如果连隔张也不能构成的话,则执行(7)
(7)将本牌的数目减1,混子数+2. 然后对下张牌重复操作(1).这一步的目的是给每个单张补两张混.
算法执行实例:
设手牌为358饼57条115689万
对筒子牌的计算过程为
去掉隔连35筒,需要1个混子
去掉单牌8筒,需要2个混子
所以饼牌成型最少需要3张混
对条牌的计算过程
去掉隔连57条,需要1个混子
条牌成型最少需要1张混
对万字牌的计算过程:
去掉一对1万,需要1个混子
去掉二连56万,需要1个混子
去掉二连89万,需要1个混子
所以万牌最少需要3张混
所以这个手牌想完全成型的话总共需要3+1+3=7张混.
字牌(东西南北中发白)的最小补混数目非常好算:
因为每个字牌的数目只能为1到4。设某个字牌的数目为n.
显然n=3时不需要胡混, n=1或者n=4时需要补两个混.n=2时补一个混才能成型.
下面看一个字牌的最小补混实例.
比如设一组字牌为 东东东西北北北中中发
这手字牌最少需要5张混,即要补两个西风 一个红中 两个发财.
基本胡牌算法
设一组牌的数目为3N+2,且牌中可能含有混子,则判断这组牌是否已经胡牌的算法为
(1)找出所有数目>=2的牌(不包括混),作为将牌的候选列表
(2)对每个候选将牌,判断去掉这组将头之后,用上一节 的算法判断让剩余牌成型的混子数是否不超过剩余的混子数,如果满足的话则说明原来的牌是胡牌,算法结束,返回成功
(3)如果所有的将头尝试完还不能胡,如果手牌中有混的话,则依次尝试将手中的单牌和一个混组成将头,然后仍然用上一节 的算法判断剩余的牌成型所需的混子数是否不超过剩余的混子数,如果某次尝试成型的话,则算法结束,,返回成功.如果所有的单牌都尝试之后还不行,就返回失败.
加速技巧
为了避免过多的重复计算,再去掉将头之前,我们可以先一次分别计算好饼 条 万 字各们的最小补混数目.这样可以避免重复计算,加快运行速度.比如
如果选了2张万字做将头,那么饼 条 和字的最小补混数目就不需要再重复计算了,可以直接使用.
我们只需要计算需要这组将头之后的万字们的最小补混数即可.
一些实例
下面是我构造的一些天胡带混的实例
0张混 : 33饼345777条123万北北北
1张混 : 22567饼12555678万混
2张混 : 111饼44466条7799万混混
3张混 : 55饼222条666777万混混混
4张混 : 1119饼115999万混混混混
5张混 : 6饼12388万发发发混混混混混
6张混 : 22238饼5条56万混混混混混混
7张混 : 88饼11万东东中混混混混混混混
8张混 : 5条34667万混混混混混混混混
9张混 : 5饼4599万混混混混混混混混混
10张混 : 3条244万混混混混混混混混混混
11张混 : 5饼67万混混混混混混混混混混混
12张混 : 8饼3万混混混混混混混混混混混混
13张混 : 北混混混混混混混混混混混混混
14张混 : 混混混混混混混混混混混混混混
均在电脑上测试通过
扩展
有了上面的胡牌算法,判断听牌就很简单了,只要再尝试补一张混,判断补完的牌是否胡牌即可.下面一些听牌带混的例子,也测试通过.
0张混: 12366789条23344万
1张混: 22饼123条2233万白白白混
2张混: 2饼45条45555777万混混
3张混: 133344万北北中中混混混
4张混: 78条44556万东东混混混混
5张混: 13饼36666万发混混混混混
6张混: 666饼37条西西混混混混混混
7张混: 29饼99条66万混混混混混混混
8张混: 224万北发混混混混混混混混
9张混: 7条白白白混混混混混混混混混
10张混: 77条4万混混混混混混混混混混
11张混: 3饼5万混混混混混混混混混混混
12张混: 6万混混混混混混混混混混混混
13张混: 混混混混混混混混混混混混混
相关文章:
麻将普通胡牌算法(带混)
最近在玩腾讯的麻将游戏,但是经常需要充值,于是就想自己实现一个简单的单机麻将游戏.第一个难点就是实现胡牌的判断.这里写一下心得. 术语 本文的胡牌是指手牌构成了3N2的牌型,即一对做将,剩下的牌均为刻子(3张一样的牌)或者顺子(3张连续的牌比如234饼). 下面就是一个14张牌…...
Rust结构体详解:定义、使用及方法
Rust 是一门强调安全性和性能的系统级编程语言,它引入了结构体(struct)作为一种自定义的数据类型,允许程序员以更加灵活的方式组织和操作数据。在本篇博客中,我们将深入探讨 Rust 结构体的定义、使用以及相关概念。 什…...
LeetCode、435. 无重叠区间【中等,贪心 区间问题】
文章目录 前言LeetCode、435. 无重叠区间【中等,贪心 区间问题】题目链接及分类思路贪心、区间问题 资料获取 前言 博主介绍:✌目前全网粉丝2W,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技…...
【实战】一、Jest 前端自动化测试框架基础入门(三) —— 前端要学的测试课 从Jest入门到TDD BDD双实战(三)
文章目录 一、Jest 前端自动化测试框架基础入门7.异步代码的测试方法8.Jest 中的钩子函数9.钩子函数的作用域 学习内容来源:Jest入门到TDD/BDD双实战_前端要学的测试课 相对原教程,我在学习开始时(2023.08)采用的是当前最新版本&a…...
信息学奥赛一本通1228:书架
1228:书架 时间限制: 1000 ms 内存限制: 65536 KB 提交数: 18190 通过数: 10557 【题目描述】 John最近买了一个书架用来存放奶牛养殖书籍,但书架很快被存满了,只剩最顶层有空余。 John共有N�头奶牛(1≤N≤20,0001≤…...
红队打靶练习:GLASGOW SMILE: 1.1
目录 信息收集 1、arp 2、nmap 3、nikto 4、whatweb 目录探测 1、gobuster 2、dirsearch WEB web信息收集 /how_to.txt /joomla CMS利用 1、爆破后台 2、登录 3、反弹shell 提权 系统信息收集 rob用户登录 abner用户 penguin用户 get root flag 信息收集…...
网络安全的今年:量子、生成人工智能以及 LLM 和密码
尽管世界总是难以预测,但网络安全的几个强劲趋势表明未来几个月的发展充满希望和令人担忧。有一点是肯定的:2024 年将是非常重要且有趣的一年。 近年来,人工智能(AI)以令人难以置信的速度发展,其在网络安全…...
【FPGA】Verilog:奇偶校验位发生器 | 奇偶校验位校验器
目录 0x00 奇偶校验位发生器 0x01 奇偶校验位校验器 0x02 错误检测器和纠错器...
【心得】关于STM32中RTC的校准方法
最近看了一些关于RTC校准的帖子,发现很多人存在疑惑。正好最近我也在STM32中实现了RTC校准。发些心得。这些对老手来说有些罗索,但对新手有益处。 实现RTC 校准的核心之一是库文件Stm321f0x_bkp.c中的void BKP_SetRTCCalibrationValue (uint8_t Calibra…...
消息中间件面试篇
目录 消息中间件 RabbitMQ 消息不丢失 生产者确认机制 消息持久化 交换机持久化 队列持久化 消息持久化 消费者确认 消息重复消费 出现的场景 解决方案 每条消息设置一个唯一的标识id 幂等方案:【 分布式锁、数据库锁(悲观锁、乐观锁&#…...
【MySQL】-20 MySQL综合-6(MySQL创建数据表+MySQL修改数据表+MySQL删除数据表)
MySQL创建数据表MySQL修改数据表MySQL删除数据表 MySQL创建数据表基本语法在指定的数据库中创建表查看表结构 MySQL修改数据表基本语法添加字段修改字段数据类型删除字段修改字段名称修改表名 MySQL删除数据表基本语法删除表 MySQL创建数据表 在创建数据库之后,接下…...
linux查看当前连接的IP
linux下查询当前所有连接的ip_linux查看某个ip的连接-CSDN博客 netstat -ntu | grep tcp | awk {print $5} | cut -d: -f1 | sort | uniq -c | sort -nr...
洛谷_P1923 【深基9.例4】求第 k 小的数_python写法
哪位大佬可以出一下这个的题解?????话说蓝桥杯可以用numpy库吗?????? 这道题有一个很简单的思路就是排序完成之后再访问。 but有很大的问题&…...
【MySQL】学习约束和使用图形化界面创建表
🌈个人主页: Aileen_0v0 🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 💫个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-iqtbME2KmWpQFQSt {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…...
QGIS编译(跨平台编译)之四十八:pixman编译(Windows、Linux、MacOS环境下编译)
文章目录 一、pixman介绍二、pixman下载三、Linux下编译四、MacOS下编译五、Windows下编译一、pixman介绍 Pixman 是一个开源的图形库,它提供了底层像素操作功能,包括像素格式转换、图像合成、图像缩放、图像旋转等多种操作。Pixman 主要被用作 Cairo 图形库的后端,支持 Ca…...
华为数通方向HCIP-DataCom H12-821题库(单选题:441-460)
第441题 下面是一台路由输出的信息,关于这段信息描述正确的是 <R1>display bgp peerBGP local router ID : 2.2.2.2Local AS number : 100Total number of peers : 2 Peers in established state : 0Peer V AS MsgRcvd MsgSent OutQ Up/Down …...
【sass】 中使用 /deep/ 修改 elementUI 组件样式报错
element plus 想要覆盖组件的样式,想到了/deep/样式穿透,但样式一直不生效,代码如下: <style scoped lang"sass"> .main_wrapper{padding: 0 53pxposition: relativetop: -20px } >>> .el-tabs__item{h…...
Python算法题集_排序链表
Python算法题集_排序链表 题148:排序链表1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【冒泡大法】2) 改进版一【列表排序】3) 改进版二【数值归并排序】4) 改进版三【快慢指针归并排序】 4. 最优算法 本文为Python算法题集之一的…...
红日靶场2学习
靶场下载来自: http://vulnstack.qiyuanxuetang.net/vuln/detail/3/ 靶场统一登录密码:1qazWSX 按大佬的说法是 环境需要模拟内网和外网两个网段,PC端虚拟机相当于网关服务器,所以需要两张网卡,一个用来向外网提供web…...
将 下载下来的 jar 包 安装到本地的 maven 仓库中
使用管理员权限 打开一个 cmd 窗口输入 mvn -v 查看 maven 版本由于之前 并没有这样的操作所以第一次 执行的时候 提示 命令不存在所以需要将 maven 软件中的 bin 文件的目录 添加到 环境变量中 的 path 变量 中本机路径为:D:\Program Files (x86)\apache-maven-3.5.2\bin C:\…...
Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...
MySQL中【正则表达式】用法
MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...
在Ubuntu24上采用Wine打开SourceInsight
1. 安装wine sudo apt install wine 2. 安装32位库支持,SourceInsight是32位程序 sudo dpkg --add-architecture i386 sudo apt update sudo apt install wine32:i386 3. 验证安装 wine --version 4. 安装必要的字体和库(解决显示问题) sudo apt install fonts-wqy…...
【Linux】Linux安装并配置RabbitMQ
目录 1. 安装 Erlang 2. 安装 RabbitMQ 2.1.添加 RabbitMQ 仓库 2.2.安装 RabbitMQ 3.配置 3.1.启动和管理服务 4. 访问管理界面 5.安装问题 6.修改密码 7.修改端口 7.1.找到文件 7.2.修改文件 1. 安装 Erlang 由于 RabbitMQ 是用 Erlang 编写的,需要先安…...
FOPLP vs CoWoS
以下是 FOPLP(Fan-out panel-level packaging 扇出型面板级封装)与 CoWoS(Chip on Wafer on Substrate)两种先进封装技术的详细对比分析,涵盖技术原理、性能、成本、应用场景及市场趋势等维度: 一、技术原…...
python基础语法Ⅰ
python基础语法Ⅰ 常量和表达式变量是什么变量的语法1.定义变量使用变量 变量的类型1.整数2.浮点数(小数)3.字符串4.布尔5.其他 动态类型特征注释注释是什么注释的语法1.行注释2.文档字符串 注释的规范 常量和表达式 我们可以把python当作一个计算器,来进行一些算术…...
scan_mode设计原则
scan_mode设计原则 在进行mtp controller设计时,基本功能设计完成后,需要设计scan_mode设计。 1、在进行scan_mode设计时,需要保证mtp处于standby模式,不会有擦写、编程动作。 2、只需要固定mtp datasheet说明的接口即可…...
分布式计算框架学习笔记
一、🌐 为什么需要分布式计算框架? 资源受限:单台机器 CPU/GPU 内存有限。 任务复杂:模型训练、数据处理、仿真并发等任务耗时严重。 并行优化:通过任务拆分和并行执行提升效率。 可扩展部署:适配从本地…...
[electron]预脚本不显示内联script
script-src self 是 Content Security Policy (CSP) 中的一个指令,它的作用是限制加载和执行 JavaScript 脚本的来源。 具体来说: self 表示 当前源。也就是说,只有来自当前网站或者当前页面所在域名的 JavaScript 脚本才被允许执行。"…...
