趁老王不在,和隔壁鄰居鬥鬥地主,比比大小

来源:https://www.cnblogs.com/moonhmily/archive/2019/08/06/11306668.html
-Advertisement-
Play Games

這幾天又空閑下來了,手癢癢,就想找隔壁鄰居玩一玩鬥地主,趁老王不在家,消遣下無聊的時光。 現在但是每次在玩的時候,老是被鄰居的穿著干擾到,我就在想是不是可以用python來搞一搞這個鬥地主,然後讓我專註在鄰居身上,哦不,是鄰居的牌身上。 ...


這幾天又空閑下來了,手癢癢,就想找隔壁鄰居玩一玩鬥地主,趁老王不在家,消遣下無聊的時光。

現在但是每次在玩的時候,老是被鄰居的穿著干擾到,我就在想是不是可以用python來搞一搞這個鬥地主,然後讓我專註在鄰居身上,哦不,是鄰居的牌身上。

基本規則

撲克牌一副由 54 張組成,含 3~A,2 各 4 張,小王 1 張,大王 1 張。牌面從小到大用如下字元和字元串表示(其中,小寫 joker 表示小王,大寫 JOKER 表示大王)。

1、輸入每手牌可能是個子,對子,順子(連續5張),三個,炸彈(四個)和對王中的一種,不存在其他情況。

2、除了炸彈和對王可以和所有牌比較之外,其他類型的牌只能跟相同類型的存在比較關係(如,對子跟對子比較,三個跟三個比較),不考慮拆牌情況(如:將對子拆分成個子)

3、大小規則跟大家平時瞭解的常見規則相同,個子,對子,三個比較牌面大小;順子比較最小牌大小;炸彈大於前面所有的牌,炸彈之間比較牌面大小;對王是最大的牌;

4、輸入的兩手牌不會出現相等的情況

輸入描述

輸入兩手牌,兩手牌之間用“-”連接,每手牌的每張牌以空格分隔,“-”兩邊沒有空格

大致思路

1、首先因為花牌需要和大小王是沒有一個數字的,所以要把花牌和大小王轉換成數字。這裡J、Q、K、A、2、joker、JOKER分別是11-17。

#  將每張J、Q、K、A、2,joker,JOKER都轉換成具體的數字11-17
def replaceFlower(nums):
    nums = nums.replace('JOKER','17')
    nums = nums.replace('joker','16')
    nums = nums.replace('2','15')
    nums = nums.replace('A','14')
    nums = nums.replace('K','13')
    nums = nums.replace('Q','12')
    nums = nums.replace('J','11')
    return nums

2、了方便計算數值,把轉換過後的數字變成int數組

# 如何將一個字元串數組轉換成整型數組,方便最大、最小值比較
firstChange =  list(map(int,firstChange))
secondChange = list(map(int,secondChange))

3、判斷是否是炸彈

# 判斷是否是炸彈
def isBomb(nums):
    # 如果是4位數,並且是相同的值,那就是炸彈
    if len(nums) == 4 and min(nums) == max(nums):
        return True

    # 如果是2張牌,加起來是33,那就是王炸
    if len(nums) == 2 and sum(nums) == 33:
        return True
    return False

4、5個數字以下的,只能出單個,對子,三個,四個即最大值和最小值必然相同才能算有效;5個數字的,考慮是否是順子

# 判斷輸入的值是否正確
def isValidNums(nums):
    # 5個數字以下的,只能出單個,對子,三個,四個即最大值和最小值必然相同才能算有效
    if len(nums) > 0 and len(nums) < 5 and (max(nums) == min(nums)):
        return True
    # 5個數字的,考慮是否是順子
    elif len(nums) == 5:
        return isContinuous(nums)

    return False

def isContinuous(nums):
    # 對數字進行排序
    nums.sort()

    for i in range(len(nums) - 1):
        # 相鄰兩個數之間相同,肯定不是順子
        if nums[i] == nums[i + 1]:
            return False

        # 後一個比前一個多1,繼續執行
        if nums[i + 1] == nums[i] + 1:
            continue
        else:
            return False

    return True

5、把每個數組的值進行相應的求和,得到這個數組的結果,才能進行兩個數組的大小比較

def isContinuous(nums):
    # 對數字進行排序
    nums.sort()

    for i in range(len(nums) - 1):
        # 相鄰兩個數之間相同,肯定不是順子
        if nums[i] == nums[i + 1]:
            return False

        # 後一個比前一個多1,繼續執行
        if nums[i + 1] == nums[i] + 1:
            continue
        else:
            return False

    return True

6、來到最後一步,就是比較大小的邏輯了

def compareNums(firstChange, secondChange, first, second):
    if sum(firstChange) > sum(secondChange):
        print(first)
    else:
        print(second)

好吧,看上去還是有點複雜的,來來回回需要經過6個步驟才能走完一個流程。看來,要想和鄰居打好鬥地主,還得多思考。畢竟,咱們的門票錢不能陪了不是

執行大小比較

當上面所有的步驟都分拆好了,現在要做的自然就是把分拆的代碼應用起來。是否是合法輸入,是否走炸彈流程,是否走比較流程等等。

# 判斷輸入的兩個數據是否相等,如果不等,需要判斷是不是炸,否則直接輸出錯誤
if len(firstChange) != len(secondChange):
    if isBomb(firstChange) or isBomb(secondChange):
        compareNums(firstChange, secondChange, first, second)
    else:
        print("You input is Error")

else:
    # 判斷是否是合法數據
    if isValidNums(firstChange) == False:
        print("You first input is Error " + str(firstChange))

    elif isValidNums(secondChange) == False:
        print("You second input is Error " + str(secondChange))
    else:
        # 合法數據,則進行結果輸出
        compareNums(firstChange, secondChange, first, second)

現在,就請你輸入幾組數據,看看吧。比如對A VS 對2,順子3 4 5 6 7 VS 6 7 8 9 10

A A-2 2
2 2

請輸入你所要出的牌,用-隔開:
3 4 5 6 7-6 7 8 9 10
6 7 8 9 10

代碼安排完了,結果也執行完了,但我的心還飄在隔壁。

現在就差一個人了……這樣才感覺到自己存在的價值,才感覺過的很有趣。

關註公眾號「Python專欄」,更多好玩有趣的Python等著你~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 阻塞與非阻塞 阻塞:A程式調用B程式,A等待返回結果,等待中A程式線程被占用,不進行其它操作。 非阻塞:A程式調用B程式,A程式線程不被占用。 阻塞--》非阻塞 的最常用解決方案:緩存,A將請求依次裝入緩存中,A不管與B是否執行完成,由B隨後依次處理,返回給A。 同步與非同步 同步:一個線程依次執行所 ...
  • 一、小案例分析 1、功能需求: 實現一個發送信息的功能,要便於擴展與維護。(1)發送信息的工具有很多,比如簡訊、微信、郵件、QQ等。(2)選擇某個工具進行信息發送。 2、小菜雞去實現: (1)定義一個發送工具的父類(介面),並將各種發送工具作為子類(實現類)。(2)定義一個選擇發送工具的類,用於調用 ...
  • 架構雜談《九》 微服務與輕量級通信機制 微服務架構是一種架構模式,它提倡將單一應用程式劃分成一組小的服務,服務之間胡亮協調、互相配合,為用戶提供最終價值。在微服務架構中,服務與服務之間通信時,通常是通過輕量級的通信機制,實現彼此間的互通互聯、互相協作。所謂輕量級通信機制,通常是指與語言無關、與平臺無 ...
  • 介紹 開閉原則是編程設計中最基本、最重要的原則。 定義:一個軟體實體如類、方法和模塊等,應該對擴展(提供方)開放,對修改(使用方)關閉。用抽象構建框架,用實現擴展細節。 也就是說,在需求發生新的變化時,我們不應該修改原來的代碼,而應該通過擴展來滿足新的需求。 例子引入 我們要實現一個畫圖的功能,能夠 ...
  • 前言 上一節中我們介紹了,依賴倒置,依賴倒置利用抽象的穩定性來架構我們的系統,是我們經常能遇到的一種原則,比如說面向介面編程。 這一節中,我們來說說里氏替換原則,這個原則其實非常非常的簡單,其實與依賴倒置相結合來看,就是希望我們用 抽象的方法 來構建項目而非 具體的實現 ,里氏替換原則就是推薦我們不 ...
  • 1.內容引入——繼承體系的思考 在繼承中,凡是在父類已經實現的方法,其實算是一種契約或者規範,子類不應該在進行更改(重寫);但是,由於這一點不是強制要求,所以當子類進行重寫的時候,就會對繼承體系產生破壞。 同時,繼承帶來便利的時候,也有弊端:給程式帶來了侵入性,增加了對象之間的耦合性,可移植性低。當 ...
  • 依賴倒置原則(Dependence Inversion Priiciple,DIP) 介紹 High level modules should not depend upon low level modules. Both should depend upon abstractions. Abstr ...
  • 設計模式詳解(總綱) 原文地址:https://www.cnblogs.com/zuoxiaolong/p/pattern1.html 作者:zuoxiaolong8810(左瀟龍),轉載請註明出處,特別說明:本博文來自博主原博客,為保證新博客中博文的完整性,特複製到此留存,如需轉載請註明新博客地址 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...