智能麻將出牌組件

開篇引言?

麻將作為一款風靡全球的策略性游戲,其復雜的規則和多變的牌局給玩家帶來了無盡樂趣。在數字化時代,運用編程技術為麻將游戲賦予智能,實現自動出牌功能,不僅能提升玩家體驗,還能深入探索算法在博弈游戲中的應用。今天,就和大家分享我如何使用 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

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901647.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901647.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901647.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

“大灣區珠寶藝境花園”璀璨綻放第五屆消博會

2025年4月13日&#xff0c;第五屆中國國際消費品博覽會&#xff08;以下簡稱"消博會"&#xff09;重要主題活動——《大灣區珠寶藝境花園》啟動儀式在海南國際會展中心2號館隆重舉行。由廣東省金銀珠寶玉器業廠商會組織帶領粵港澳大灣區優秀珠寶品牌&#xff0c;以“…

基于前端技術的QR碼API開發實戰:從原理到部署

前言 QR碼&#xff08;Quick Response Code&#xff09;是一種二維碼&#xff0c;于1994年開發。它能快速存儲和識別數據&#xff0c;包含黑白方塊圖案&#xff0c;常用于掃描獲取信息。QR碼具有高容錯性和快速讀取的優點&#xff0c;廣泛應用于廣告、支付、物流等領域。通過掃…

利用耦合有限元和神經網絡計算的骨重塑模擬多尺度方法

Multiscale methodology for bone remodelling simulation using coupled finite element and neural network computation 摘要&#xff1a;本文旨在開發一種基于有限元分析&#xff08;FEA&#xff09;和神經網絡&#xff08;NN&#xff09;計算的多尺度分層混合模型&#xf…

使用異步特征引發的錯誤error[E0195]: lifetime parameters or bounds on method `before_save`

問題描述&#xff1a; 使用SeaOrm保存實體到數據庫時不想每次都設置更新時間&#xff0c;所以想通過實現ActiveModelBehavior在保存實體前統一設置更新時間 impl ActiveModelBehavior for ActiveModel {async fn before_save<C>(self, _db: &C, _insert: bool) -&…

TVS管與ESD保護二極管詳解:原理、區別與應用選型

一、TVS管&#xff08;瞬態電壓抑制二極管&#xff09; 1. 基本定義 TVS管&#xff08;Transient Voltage Suppressor&#xff09; 是一種用于抑制瞬態高壓脈沖的半導體器件&#xff0c;通過雪崩擊穿效應快速鉗位電壓&#xff0c;保護后端電路。 2. 核心特性參數 參數定義公…

Day08 【基于jieba分詞實現詞嵌入的文本多分類】

基于jieba分詞的文本多分類 目標數據準備參數配置數據處理模型構建主程序測試與評估測試結果 目標 本文基于給定的詞表&#xff0c;將輸入的文本基于jieba分詞分割為若干個詞&#xff0c;然后將詞基于詞表進行初步編碼&#xff0c;之后經過網絡層&#xff0c;輸出在已知類別標…

入門-C編程基礎部分:6、常量

飛書文檔https://x509p6c8to.feishu.cn/wiki/MnkLwEozRidtw6kyeW9cwClbnAg C 常量 常量是固定值&#xff0c;在程序執行期間不會改變&#xff0c;可以讓我們編程更加規范。 常量可以是任何的基本數據類型&#xff0c;比如整數常量、浮點常量、字符常量&#xff0c;或字符串字…

第二階段:數據結構與函數

模塊4&#xff1a;常用數據結構 (Organizing Lots of Data) 在前面的模塊中&#xff0c;我們學習了如何使用變量來存儲單個數據&#xff0c;比如一個數字、一個名字或一個布爾值。但很多時候&#xff0c;我們需要處理一組相關的數據&#xff0c;比如班級里所有學生的名字、一本…

【C++算法】61.字符串_最長公共前綴

文章目錄 題目鏈接&#xff1a;題目描述&#xff1a;解法C 算法代碼&#xff1a;解釋 題目鏈接&#xff1a; 14. 最長公共前綴 題目描述&#xff1a; 解法 解法一&#xff1a;兩兩比較 先算前兩個字符串的最長公共前綴&#xff0c;然后拿這個最長公共前綴和后面一個來比較&…

JVM 調優不再難:AI 工具自動生成內存優化方案

在 Java 應用程序的開發與運行過程中&#xff0c;Java 虛擬機&#xff08;JVM&#xff09;的性能調優一直是一項極具挑戰性的任務&#xff0c;尤其是內存優化方面。不合適的 JVM 內存配置可能會導致應用程序出現性能瓶頸&#xff0c;甚至頻繁拋出內存溢出異常&#xff0c;影響業…

紛析云開源財務軟件:企業財務數字化轉型的靈活解決方案

紛析云是一家專注于開源財務軟件研發的公司&#xff0c;自2018年成立以來&#xff0c;始終以“開源開放”為核心理念&#xff0c;致力于通過技術創新助力企業實現財務管理的數字化與智能化轉型。其開源財務軟件憑借高擴展性、靈活部署和全面的功能模塊&#xff0c;成為眾多企業…

【數字圖像處理】數字圖像空間域增強(3)

圖像銳化 圖像細節增強 圖像輪廓&#xff1a;灰度值陡然變化的部分 空間變化&#xff1a;計算灰度變化程度 圖像微分法&#xff1a;微分計算灰度梯度突變的速率 一階微分&#xff1a;單向差值 二階微分&#xff1a;雙向插值 一階微分濾波 1&#xff1a;梯度法 梯度&#xff1…

基于Linux的ffmpeg python的關鍵幀抽取

1.FFmpeg的環境配置 首先強調&#xff0c;ffmpeg-python包與ffmpeg包不一樣。 1) 創建一個虛擬環境env conda create -n yourenv python3.x conda activate yourenv2) ffmpeg-python包的安裝 pip install ffmpeg-python3) 安裝系統級別的 FFmpeg 工具 雖然安裝了 ffmpeg-p…

C#進階學習(四)單向鏈表和雙向鏈表,循環鏈表(上)單向鏈表

目錄 前置知識&#xff1a; 一、鏈表中的結點類LinkedNode 1、申明字段節點類&#xff1a; 2、申明屬性節點類: 二、兩種方式實現單向鏈表 ①定框架&#xff1a; ②增加元素的方法&#xff1a;因為是單鏈表&#xff0c;所以增加元素一定是只能在末尾添加元素&#xff0c;…

RK3588 Buildroot 串口測試工具

RK3588 Buildroot串口測試工具(含代碼) 一、引言 1.1 目的 本文檔旨在指導開發人員能快速測試串口功能 1.2 適用范圍 本文檔適用于linux 系統串口測試。 二、開發環境準備 2.1 硬件環境 開發板:RK3588開發板,確保其串口硬件連接正常,具備電源供應、調試串口等基本硬…

HOJ PZ

https://docs.hdoi.cn/deploy 單體部署 請到~/hoj-deploy/standAlone的目錄下&#xff0c;即是與docker-compose.yml的文件同個目錄下&#xff0c;該目錄下有個叫hoj的文件夾&#xff0c;里面的文件夾介紹如下&#xff1a; hoj ├── file # 存儲了上傳的圖片、上傳的臨…

EtherCAT 的優點與缺點

EtherCAT&#xff08;以太網控制自動化技術&#xff09;是一種高性能的工業以太網協議&#xff0c;廣泛應用于實時自動化控制。以下是其核心優缺點分析&#xff1a; ?一、EtherCAT 的核心優點? 1. ?超低延遲 & 高實時性? ?原理?&#xff1a;采用"?Processing…

高并發多級緩存架構實現思路

目錄 1.整體架構 3.安裝環境 1.1 使用docket安裝redis 1.2 配置redis緩存鏈接&#xff1a; 1.3 使用redisTemplate實現 1.4 緩存注解優化 1.4.1 常用緩存注解簡紹 1.4.2 EnableCaching注解的使用 1.4.3使用Cacheable 1.4.4CachePut注解的使用 1.4.5 優化 2.安裝Ngin…

Qt QML實現Windows桌面顏色提取器

前言 實現一個簡單的小工具&#xff0c;使用Qt QML實現Windows桌面顏色提取器&#xff0c;實時顯示鼠標移動位置的顏色值&#xff0c;包括十六進制值和RGB值。該功能在實際應用中比較常見&#xff0c;比如截圖的時候&#xff0c;鼠標移動就會在鼠標位置實時顯示坐標和顏色值&a…

vue3+vite 多個環境配置

同一套代碼 再也不用在不同的環境里來回切換請求地址了 然后踩了一個坑 就是env的文件路徑是在當前項目下 不是在views內 因為公司項目需求只有dev和pro兩個環境 雖然我新增了3個 但是只在這兩個里面配置了 .env是可以配置一些公共配置的 目前需求來說不需要 所以我也懶得配了。…