井字棋——ai PK you

挑戰人工智能,體驗經典井字棋的對決!AI 擁有強大的邏輯計算能力,每一步都經過精準推演。你能戰勝它嗎?還是會被 AI 徹底碾壓?

特點:

智能 AI,難度可調
極簡界面,快速上手
實時勝負統計,見證你的進步


代碼如下:

import sys
from random import choice
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton, QMessageBox, QVBoxLayout, QHBoxLayout, QLabel
from PyQt5.QtCore import Qtclass TicTacToe(QWidget):def __init__(self):super().__init__()self.setWindowTitle('井字棋游戲')self.setGeometry(100, 100, 400, 400)self.buttons = []self.current_player = 'X'  # 玩家是X,AI是Oself.game_over = Falseself.board = ['' for _ in range(9)]self.initUI()def initUI(self):# 頂部信息標簽self.info_label = QLabel("玩家的回合 - 點擊格子放置X", self)self.info_label.setAlignment(Qt.AlignCenter)# 創建3x3按鈕網格layout = QVBoxLayout()layout.addWidget(self.info_label)for i in range(3):row = QHBoxLayout()for j in range(3):index = i * 3 + jbutton = QPushButton('', self)button.setFixedSize(100, 100)button.clicked.connect(lambda _, idx=index: self.button_clicked(idx))row.addWidget(button)self.buttons.append(button)layout.addLayout(row)# 重新開始按鈕restart_button = QPushButton('重新開始', self)restart_button.clicked.connect(self.reset_game)layout.addWidget(restart_button)self.setLayout(layout)def button_clicked(self, index):if self.game_over or self.board[index] != '' or self.current_player != 'X':return# 玩家下棋self.board[index] = 'X'self.buttons[index].setText('X')self.buttons[index].setEnabled(False)# 檢查游戲是否結束if self.check_winner('X'):self.info_label.setText("玩家勝利!")self.game_over = TrueQMessageBox.information(self, "游戲結束", "你贏了!", QMessageBox.Ok)return# 檢查是否平局if '' not in self.board:self.info_label.setText("平局!")self.game_over = TrueQMessageBox.information(self, "游戲結束", "平局!", QMessageBox.Ok)return# AI下棋self.ai_move()def ai_move(self):self.current_player = 'O'self.info_label.setText("AI的回合...")# 簡單AI: 隨機選擇一個空格子empty_spots = [i for i, val in enumerate(self.board) if val == '']if empty_spots:# 可以在這里實現更復雜的AI邏輯move = self.simple_ai()self.board[move] = 'O'self.buttons[move].setText('O')self.buttons[move].setEnabled(False)self.info_label.setText("玩家的回合 - 點擊格子放置X")self.current_player = 'X'# 檢查游戲是否結束if self.check_winner('O'):self.info_label.setText("AI勝利!")self.game_over = TrueQMessageBox.information(self, "游戲結束", "AI贏了!", QMessageBox.Ok)return# 檢查是否平局if '' not in self.board:self.info_label.setText("平局!")self.game_over = TrueQMessageBox.information(self, "游戲結束", "平局!", QMessageBox.Ok)returndef simple_ai(self):# 先檢查是否有必勝的機會for i in range(9):if self.board[i] == '':self.board[i] = 'O'if self.check_winner('O'):self.board[i] = ''return iself.board[i] = ''# 如果沒有必勝機會,再檢查是否需要阻擋玩家for i in range(9):if self.board[i] == '':self.board[i] = 'X'if self.check_winner('X'):self.board[i] = ''return iself.board[i] = ''# 如果沒有必勝或阻擋的必要,嘗試占據中心if self.board[4] == '':return 4# 嘗試占據角位corners = [0, 2, 6, 8]empty_corners = [i for i in corners if self.board[i] == '']if empty_corners:return choice(empty_corners)# 最后選擇邊位edges = [1, 3, 5, 7]empty_edges = [i for i in edges if self.board[i] == '']return choice(empty_edges) if empty_edges else -1def check_winner(self, player):# 檢查行for i in range(0, 9, 3):if self.board[i] == self.board[i + 1] == self.board[i + 2] == player:return True# 檢查列for i in range(3):if self.board[i] == self.board[i + 3] == self.board[i + 6] == player:return True# 檢查對角線if self.board[0] == self.board[4] == self.board[8] == player:return Trueif self.board[2] == self.board[4] == self.board[6] == player:return Truereturn Falsedef reset_game(self):for i in range(9):self.buttons[i].setText('')self.buttons[i].setEnabled(True)self.board = ['' for _ in range(9)]self.current_player = 'X'self.game_over = Falseself.info_label.setText("玩家的回合 - 點擊格子放置X")if __name__ == '__main__':app = QApplication(sys.argv)game = TicTacToe()game.show()sys.exit(app.exec_())

效果展示:
在這里插入圖片描述

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

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

相關文章

關于easyx頭文件

一、窗口創建 &#xff08;1&#xff09;幾種創建方式 #include<easyx.h>//easyx的頭文件 #include<iostream> using namespace std;int main() {//創建一個500*500的窗口//參數為&#xff1a;長度&#xff0c;寬度&#xff0c;是否顯示黑框&#xff08;無參為不…

【學習記錄】Django Channels + WebSocket 異步推流開發常用命令匯總

文章目錄 &#x1f4cc; 摘要&#x1f9f0; 虛擬環境管理? 創建虛擬環境? 刪除虛擬環境? 激活/切換虛擬環境 &#x1f6e0;? Django 項目管理? 查看 Django 版本? 創建 Django 項目? 創建 Django App &#x1f4ac; Channels 常用操作? 查看 Channels 版本 &#x1f50…

Java線程狀態及其流轉

在Java編程中&#xff0c;線程是一種重要的并發實體。為了更好地理解和管理多線程應用程序&#xff0c;我們需要清楚線程的不同狀態及其流轉機制。本文將詳細介紹Java中線程的幾種主要狀態以及它們之間的轉換關系。 一、線程狀態概述 Java線程的生命周期有多個狀態&#xff0…

LabVIEW雙光子顯微鏡開發

基于LabVIEW 開發高性能雙光子顯微鏡系統&#xff0c;聚焦于生物樣本深層成像與納米材料三維表征。實現了超快激光控制、多維數據采集與實時圖像重建。系統采用飛秒激光光源與高精度振鏡掃描模塊&#xff0c;結合 LabVIEW 的 FPGA 實時控制能力&#xff0c;可對活體組織、熒光納…

數據庫操作-MySQL-4(JDBC編程)

JDBC&#xff1a;通過Java代碼操作mysql數據庫&#xff0c;數據庫會提供一些API供我們調用 MySQL、Oracle、等API有差異&#xff0c;但是Java統一了所有接口&#xff0c;即JDBC&#xff1b; 原始api-驅動包&#xff08;類似轉接頭&#xff09;-統一的api-Java 驅動包&#xff1…

windows修改躍點數調整網絡優先級

Windows有兩個網卡&#xff0c;一個有線網卡&#xff0c;一個無線網卡&#xff0c;通過修改躍點數來調整優先使用的網卡&#xff0c;這種只是眾多設置方式中的其中一種設置方式 文檔編寫時間&#xff1a;2025年6月 1.打開電腦的網絡連接 cmd--ncpa.cpl 在cmd中運行ncpa.cpl可…

實驗設計與分析(第6版,Montgomery著,傅玨生譯) 第10章擬合回歸模型10.9節思考題10.1 R語言解題

本文是實驗設計與分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅玨生譯) 第10章擬合回歸模型10.9節思考題10.1 R語言解題。主要涉及線性回歸、回歸的顯著性、回歸系數的置信區間。 vial <- seq(1, 10, 1) Viscosity <- c(160,171,175,182,184,181,188,19…

【深入 LangChain 的 Model I/O】提示設計、模型調用與輸出解析全解析

目錄 什么是 Model I/O&#xff1f; 一、提示模板&#xff08;PromptTemplate&#xff09; 1.1 什么是提示模板&#xff1f; 1.2 常見提示模板類型 二、模型調用&#xff08;Model Predict&#xff09; 三、輸出解析&#xff08;Output Parser&#xff09; 綜合示例&…

OD 算法題 B卷【跳格子2】

文章目錄 跳格子2 跳格子2 小明和朋友玩跳格子游戲&#xff0c;有n個連續格子組成的圓圈&#xff0c;每個格子有不同的分數&#xff0c;小朋友可以選擇從任意格子起跳&#xff0c;但是不能跳連續的格子&#xff0c;不能回頭跳&#xff0c;也不能超過一圈&#xff0c;給定一個代…

客戶線索商機怎么管?客戶線索商機管理工具哪個好?

做銷售、搞運營的朋友肯定都有過這種煩惱&#xff1a;每天收到海量客戶線索&#xff0c;卻不知道從哪條開始跟進&#xff1b;試了好幾個管理工具&#xff0c;要么功能太復雜&#xff0c;要么用起來不趁手。其實選對客戶線索商機管理工具&#xff0c;就像找到靠譜的 “銷售小助手…

008房屋租賃系統技術揭秘:構建智能租賃服務生態

房屋租賃系統技術揭秘&#xff1a;構建智能租賃服務生態 在房地產租賃市場日益活躍的當下&#xff0c;房屋租賃系統成為連接房東與租客的重要數字化橋梁。該系統集成用戶管理、房屋信息等多個核心模塊&#xff0c;面向管理員、房東和用戶三類角色&#xff0c;通過前臺展示與后…

SpringBoot 系列之集成 RabbitMQ 實現高效流量控制

系列博客專欄&#xff1a; JVM系列博客專欄SpringBoot系列博客 Spring Boot 2.2.1 集成 RabbitMQ 實現高效流量控制 在分布式系統中&#xff0c;消息隊列是實現異步通信、解耦服務的重要組件。RabbitMQ 作為一款成熟的開源消息隊列&#xff0c;廣泛應用于各類項目中。本文將…

新視訊影視官網入口,影視動漫在線播放網站

新視訊影視是一個免費為廣大追劇迷提供在線播放服務的影視平臺&#xff0c;深受眾多影視愛好者的喜愛。它涵蓋了大量免費的VIP電視劇資源、最新上映的大片、好看的綜藝節目以及動漫視頻&#xff0c;是一個播放速度快、資源多的免費影視網站。用戶無需注冊或登錄&#xff0c;即可…

【使用】【經驗】docker 清理未使用的鏡像的命令

docker images prune在 Docker 中清理未使用的鏡像&#xff08;包括懸空鏡像和完全未被引用的鏡像&#xff09;&#xff0c;可以使用以下命令&#xff1a; 1. ?刪除所有懸空鏡像?&#xff08;推薦常用&#xff09; docker image prune?懸空鏡像 (dangling images)?? 是指…

OpenCV CUDA模塊圖像處理------圖像融合函數blendLinear()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 該函數執行 線性融合&#xff08;加權平均&#xff09; 兩個圖像 img1 和 img2&#xff0c;使用對應的權重圖 weights1 和 weights2。 融合公式…

【Typst】6.布局函數

概述 上節我們介紹了文檔結構元素的函數&#xff0c;本節介紹一些控制布局使用的函數&#xff0c;掌握他們之后你可以更進一步的控制頁面元素的布局。 系列目錄 1.Typst概述2.Typst標記語法和基礎樣式3.Typst腳本語法4.導入、包含和讀取5.文檔結構元素與函數6.布局函數 對齊…

【音視頻】FFmpeg 編碼H265

一、概述 實現了讀入本地yuv文件&#xff0c;通過libx265編碼為H265格式&#xff0c;并存儲到本地文件中 二、實現流程 準備文件 在build路徑下準備yuv文件 在項目中添加文件參數&#xff0c;輸出為h265文件&#xff0c;使用libx265編碼 初始化解碼器 通過傳進來的libx265…

ECreator低代碼平臺-文件管理器的使用說明

Ecreator是中山華拓信息技術公司旗下的一款低代碼平臺&#xff0c;主要功能包含&#xff1a;文件管理器&#xff0c;表單數據管理器&#xff0c;儀表盤設計界面&#xff0c;內容頁面自定義等功能&#xff0c;可以用于快速低成本的構建網站和企業內部應用。 下面介紹一下文件管…

高考加油!UI界面生成器!

這個高考助力標語生成器具有以下特點&#xff1a; 視覺設計&#xff1a;采用了藍色為主色調&#xff0c;搭配漸變背景和圓形裝飾元素&#xff0c;營造出寧靜而充滿希望的氛圍&#xff0c;非常適合高考主題。 標語生成&#xff1a;內置了超過 100 條精心挑選的高考加油標語&a…

阿姆達爾定律的演進:古斯塔夫森定律

前言 在上一篇文章《使用阿姆達爾定律來提升效率》中提到的阿姆達爾定律前提是假設問題的規模保持不變&#xff0c;并且給定一臺速度更快的機器&#xff0c;目標是更快地解決問題。然而&#xff0c;在大多數情況下&#xff0c;這并不完全正確。當有一臺更快的機器時&#xff0…