当前位置: 首页 > news >正文

智能麻将出牌组件

开篇引言​

麻将作为一款风靡全球的策略性游戏,其复杂的规则和多变的牌局给玩家带来了无尽乐趣。在数字化时代,运用编程技术为麻将游戏赋予智能,实现自动出牌功能,不仅能提升玩家体验,还能深入探索算法在博弈游戏中的应用。今天,就和大家分享我如何使用 Java 编写一个智能麻将出牌组件的过程。​

1. 麻将规则简述​

简单介绍麻将的基本规则,如牌型(顺子、刻子、对子等)、胡牌方式、不同花色牌的作用等。强调这些规则是后续智能出牌算法设计的基础。例如,因为有顺子和刻子的牌型,所以在计算出牌策略时,需要考虑如何通过出牌来促进这些牌型的形成或完善。​

11-19为1万-9万,21-29为1条到9条,31-39为1筒到9筒,41-47为东西南北中发白,51-58为梅兰竹菊春夏秋冬

2. 技术选型 - Java 的优势​

说明选择 Java 作为开发语言的原因。如 Java 强大的跨平台性,方便组件能在不同操作系统的麻将游戏中集成;丰富的类库,在处理牌的逻辑、数据结构和算法实现时能提供便捷工具;良好的面向对象特性,有利于构建清晰、可维护的代码结构等。​

3.主要的public方法

public class MahjongIntelligentModule {private Mahjong mahjong;private volatile static MahjongIntelligentModule singleton;/*** 智能模块控制方法** @param handCards     手牌* @param outCards      已出的牌* @param laiZiCards    癞子牌* @param handCard      本次需要出的牌* @param queYiMenValue 缺一门牌值* @param lastOutCard   上一次出的牌* @param noOutCardList 不能出的牌* @return 可以出的牌值*/public MahjongIntelligentModule(List<Integer> handCards, List<Integer> outCards, List<Integer> laiZiCards, int handCard, int queYiMenValue, int lastOutCard, List<Integer> noOutCardList) {……}/*** 通过智能算法获取可以出的牌值,判断出牌后听牌最大的可能性,通过outCards判断出这张牌是否还有可能胡的牌** @return 可以出的牌值*/public int getOutCard() {……}/*** 判断是否可以碰牌,通过牌型判断和outCards判断碰后是否会影响原来的牌型,加入影响则返回false,否则返回true** @return 是否可以碰牌*/public boolean getPengCard() {……}/*** 判断是否可以杠牌,通过牌型判断和outCards判断杠后是否会影响原来的牌型,加入影响则返回false,否则返回true** @return 是否可以杠牌*/public boolean getGangCard(Integer cardType) {……}}

4. 智能出牌概率计算

进张概率计算​; 拆对、刻、顺概率评估;综合出牌概率公式应用​

5. 测试与验证​

5.1 出牌测试

List<Integer> handCards = new ArrayList<>(Arrays.asList(12,13,14,15,16,17,24,26,32,33,35,37,38,26));MahjongIntelligentModule mahjongIntelligentModule = new MahjongIntelligentModule(handCards,new ArrayList<>(Arrays.asList()),new ArrayList<>(),-1,-1,-1,new ArrayList<>());int outcard = mahjongIntelligentModule.getOutCard();System.out.println("需要出的牌:"+outcard);


CardsInformationInfo{cardsInformations=……, outCard=24, maxChance=9.79}
需要出的牌:24 

 5.2 碰牌测试

List<Integer> handCards = new ArrayList<>(Arrays.asList(11,12,12,13,13,14,17));int lastoutcard = 12;MahjongIntelligentModule mahjongIntelligentModule = new MahjongIntelligentModule(handCards,new ArrayList<>(Arrays.asList()),new ArrayList<>(),-1,-1,lastoutcard,new ArrayList<>());boolean pengcard = mahjongIntelligentModule.getPengCard();System.out.println("碰的牌为:"+lastoutcard+"\t是否能碰:"+pengcard);

 碰的牌为:12    是否能碰:false

List<Integer> handCards = new ArrayList<>(Arrays.asList(11,12,12,12,13,17,17));int lastoutcard = 12;MahjongIntelligentModule mahjongIntelligentModule = new MahjongIntelligentModule(handCards,new ArrayList<>(Arrays.asList()),new ArrayList<>(),-1,-1,lastoutcard,new ArrayList<>());boolean pengcard = mahjongIntelligentModule.getPengCard();System.out.println("碰的牌为:"+lastoutcard+"\t是否能碰:"+pengcard);

 CardsInformationInfo{cardsInformations=……, outCard=17, maxChance=2.63}
出牌:17
碰的牌为:12    是否能碰:true

5.3吃牌测试

List<Integer> handCards = new ArrayList<>(Arrays.asList(11,12,12,12,13,17,17));int lastoutcard = 12;MahjongIntelligentModule mahjongIntelligentModule = new MahjongIntelligentModule(handCards,new ArrayList<>(Arrays.asList()),new ArrayList<>(),-1,-1,lastoutcard,new ArrayList<>());List<Integer> chiList = mahjongIntelligentModule.getChiCard();System.out.println("上加出的牌为:"+lastoutcard+"\t能吃的牌:"+chiList);

CardsInformationInfo{cardsInformations=……, outCard=17, maxChance=-0.15000000000000002}
出牌:17
上加出的牌为:12    能吃的牌:[11, 12, 13]

List<Integer> handCards = new ArrayList<>(Arrays.asList(12,13,14,15,16,17,18));int lastoutcard = 12;MahjongIntelligentModule mahjongIntelligentModule = new MahjongIntelligentModule(handCards,new ArrayList<>(Arrays.asList()),new ArrayList<>(),-1,-1,lastoutcard,new ArrayList<>());List<Integer> chiList = mahjongIntelligentModule.getChiCard();System.out.println("上家出的牌为:"+lastoutcard+"\t能吃的牌:"+chiList);

 上家出的牌为:12    能吃的牌:null

相关文章:

  • 【更新完毕】2025泰迪杯数据挖掘竞赛A题数学建模思路代码文章教学:竞赛论文初步筛选系统
  • 2025年广东消防设施操作员(初级)考试练习题
  • Spark大数据分析与实战笔记(第四章 Spark SQL结构化数据文件处理-05)
  • 系统与网络安全------弹性交换网络(1)
  • 解决前端vue项目在linux上,npm install,node-sass 安装失败的问题
  • 线上教学平台(vue+springboot+ssm+mysql)含文档+PPT
  • AI赋能PLC(一):三菱FX-3U编程实战初级篇
  • NoETL×大模型:Aloudata重构数据智能新范式,开启Chat BI新落地之道
  • React 高级特性与最佳实践
  • 自我生成,自我训练:大模型用合成数据实现“自我学习”机制实战解析
  • PostgreSql dump导入问题集合
  • 两个 STM32G0 I2C 通信异常的案例分析
  • Python实现贪吃蛇三
  • 软考 系统架构设计师系列知识点 —— 设计模式之创建者模式
  • OpenCv高阶(六)——图像的透视变换
  • Python 赋能区块链金融——从零构建智能交易系统
  • 生物信息与自动化控制1 - 传感器数据采集与PID 算法的应用
  • 使用Vue 3与.NET 8.0通过SignalR实现实时通信,并结合JWT身份验证
  • 十、自动化函数+实战
  • youtube视频和telegram视频加载原理差异分析
  • 建设一个视频网站需要什么/核酸检测最新消息
  • 珠海企业集团网站建设/百度查询关键词排名工具
  • 做网站时怎么更改区域内的图片/seo优化大公司排名
  • 网站建设信息表/百度seo关键词优化方案
  • 禹城网站制作/百度seo快速见效方法
  • 宝鸡网站网站建设/如何搜索关键词热度