返回顶部
首页 > 资讯 > 后端开发 > Python >基于Python如何实现围棋游戏
  • 386
分享到

基于Python如何实现围棋游戏

2023-06-30 16:06:38 386人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“基于python如何实现围棋游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“基于Python如何实现围棋游戏”吧!1.导入模块tkinter:ttk覆盖tkinter部分对象

本篇内容主要讲解“基于python如何实现围棋游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“基于Python如何实现围棋游戏”吧!

1.导入模块

tkinter:ttk覆盖tkinter部分对象,ttk对tkinter进行了优化

copy:深拷贝时需要用到copy模块

tkinter.messagebox:围棋应用对象定义

如没有以上模块,在PyCharm终端输入以下指令:

pip install 相应模块 -i https://pypi.douban.com/simple

from tkinter import *from tkinter.ttk import *import copyimport tkinter.messagebox

2.初始化棋盘

对棋盘进行初始化和棋盘右侧的按钮设置,以及对棋子的控制。

class Application(Tk):# 初始化棋盘,默认九路棋盘def __init__(self,my_mode_num=9):Tk.__init__(self)# 模式,九路棋:9,十三路棋:13,十九路棋:19self.mode_num=my_mode_num# 窗口尺寸设置,默认:1.8self.size=1.8# 棋盘每格的边长self.dd=360*self.size/(self.mode_num-1)# 相对九路棋盘的矫正比例self.p=1 if self.mode_num==9 else (2/3 if self.mode_num==13 else 4/9)# 定义棋盘阵列,超过边界:-1,无子:0,黑棋:1,白棋:2self.positions=[[0 for i in range(self.mode_num+2)] for i in range(self.mode_num+2)]# 初始化棋盘,所有超过边界的值置-1for m in range(self.mode_num+2):for n in range(self.mode_num+2):if (m*n==0 or m==self.mode_num+1 or n==self.mode_num+1):self.positions[m][n]=-1# 拷贝三份棋盘“快照”,悔棋和判断“打劫”时需要作参考self.last_3_positions=copy.deepcopy(self.positions)self.last_2_positions=copy.deepcopy(self.positions)self.last_1_positions=copy.deepcopy(self.positions)# 记录鼠标经过的地方,用于显示shadow时self.cross_last=None# 当前轮到的玩家,黑:0,白:1,执黑先行self.present=0 # 初始停止运行,点击“开始游戏”运行游戏self.stop=True# 悔棋次数,次数大于0才可悔棋,初始置0(初始不能悔棋),悔棋后置0,下棋或弃手时恢复为1,以禁止连续悔棋self.regretchance=0# 图片资源,存放在当前目录下的/Pictures/中self.photoW=PhotoImage(file = "./Pictures/W.png")self.photoB=PhotoImage(file = "./Pictures/B.png")self.photoBD=PhotoImage(file = "./Pictures/"+"BD"+"-"+str(self.mode_num)+".png")self.photoWD=PhotoImage(file = "./Pictures/"+"WD"+"-"+str(self.mode_num)+".png")self.photoBU=PhotoImage(file = "./Pictures/"+"BU"+"-"+str(self.mode_num)+".png")self.photoWU=PhotoImage(file = "./Pictures/"+"WU"+"-"+str(self.mode_num)+".png")# 用于黑白棋子图片切换的列表self.photoWBU_list=[self.photoBU,self.photoWU]self.photoWBD_list=[self.photoBD,self.photoWD]# 窗口大小self.geometry(str(int(600*self.size))+'x'+str(int(400*self.size)))# 画布控件,作为容器self.canvas_bottom=Canvas(self,bg='#369',bd=0,width=600*self.size,height=400*self.size)self.canvas_bottom.place(x=0,y=0)# 几个功能按钮self.startButton=Button(self,text='开始游戏',command=self.start)self.startButton.place(x=480*self.size,y=200*self.size)self.paSSMeButton=Button(self,text='弃一手',command=self.passme)self.passmeButton.place(x=480*self.size,y=225*self.size)self.regretButton=Button(self,text='悔棋',command=self.regret)self.regretButton.place(x=480*self.size,y=250*self.size)# 初始悔棋按钮禁用self.regretButton['state']=DISABLEDself.replayButton=Button(self,text='重新开始',command=self.reload)self.replayButton.place(x=480*self.size,y=275*self.size)self.newGameButton1=Button(self,text=('十三' if self.mode_num==9 else '九')+'路棋',command=self.newGame1)self.newGameButton1.place(x=480*self.size,y=300*self.size)self.newGameButton2=Button(self,text=('十三' if self.mode_num==19 else '十九')+'路棋',command=self.newGame2)self.newGameButton2.place(x=480*self.size,y=325*self.size)self.quitButton=Button(self,text='退出游戏',command=self.quit)self.quitButton.place(x=480*self.size,y=350*self.size)# 画棋盘,填充颜色self.canvas_bottom.create_rectangle(0*self.size,0*self.size,400*self.size,400*self.size,fill='#c51')# 刻画棋盘线及九个点# 先画外框粗线self.canvas_bottom.create_rectangle(20*self.size,20*self.size,380*self.size,380*self.size,width=3)# 棋盘上的九个定位点,以中点为模型,移动位置,以作出其余八个点for m in [-1,0,1]:for n in [-1,0,1]:self.oringinal=self.canvas_bottom.create_oval(200*self.size-self.size*2,200*self.size-self.size*2,200*self.size+self.size*2,200*self.size+self.size*2,fill='#000')self.canvas_bottom.move(self.oringinal,m*self.dd*(2 if self.mode_num==9 else (3 if self.mode_num==13 else 6)),n*self.dd*(2 if self.mode_num==9 else (3 if self.mode_num==13 else 6)))# 画中间的线条for i in range(1,self.mode_num-1):self.canvas_bottom.create_line(20*self.size,20*self.size+i*self.dd,380*self.size,20*self.size+i*self.dd,width=2)self.canvas_bottom.create_line(20*self.size+i*self.dd,20*self.size,20*self.size+i*self.dd,380*self.size,width=2)# 放置右侧初始图片self.pW=self.canvas_bottom.create_image(500*self.size+11, 65*self.size,image=self.photoW)self.pB=self.canvas_bottom.create_image(500*self.size-11, 65*self.size,image=self.photoB)# 每张图片都添加image标签,方便reload函数删除图片self.canvas_bottom.addtag_withtag('image',self.pW)self.canvas_bottom.addtag_withtag('image',self.pB)# 鼠标移动时,调用shadow函数,显示随鼠标移动的棋子self.canvas_bottom.bind('<Motion>',self.shadow)# 鼠标左键单击时,调用getdown函数,放下棋子self.canvas_bottom.bind('<Button-1>',self.getDown)# 设置退出快捷键<Ctrl>+<D>,快速退出游戏self.bind('<Control-KeyPress-d>',self.keyboardQuit)

3. 开始游戏

def start(self):# 删除右侧太极图self.canvas_bottom.delete(self.pW)self.canvas_bottom.delete(self.pB)# 利用右侧图案提示开始时谁先落子if self.present==0:self.create_pB()self.del_pW()else:self.create_pW()self.del_pB()# 开始标志,解除stopself.stop=None

4.放弃当前回合落子

点击弃一手,可跳过当前回合落子。

def passme(self):# 悔棋恢复if not self.regretchance==1:self.regretchance+=1else:self.regretButton['state']=NORMAL# 拷贝棋盘状态,记录前三次棋局self.last_3_positions=copy.deepcopy(self.last_2_positions)self.last_2_positions=copy.deepcopy(self.last_1_positions)self.last_1_positions=copy.deepcopy(self.positions)self.canvas_bottom.delete('image_added_sign')# 轮到下一玩家if self.present==0:self.create_pW()self.del_pB()self.present=1else:self.create_pB()self.del_pW()self.present=0

5.悔棋判断

若当前回合悔棋,则下两个回合都不能悔棋。

def regret(self):# 判定是否可以悔棋if self.regretchance==1:self.regretchance=0self.regretButton['state']=DISABLEDlist_of_b=[]list_of_w=[]self.canvas_bottom.delete('image')if self.present==0:self.create_pB()else:self.create_pW()for m in range(1,self.mode_num+1):for n in range(1,self.mode_num+1):self.positions[m][n]=0for m in range(len(self.last_3_positions)):for n in range(len(self.last_3_positions[m])):if self.last_3_positions[m][n]==1:list_of_b+=[[n,m]]elif self.last_3_positions[m][n]==2:list_of_w+=[[n,m]]self.recover(list_of_b,0)self.recover(list_of_w,1)self.last_1_positions=copy.deepcopy(self.last_3_positions)for m in range(1,self.mode_num+1):for n in range(1,self.mode_num+1):self.last_2_positions[m][n]=0self.last_3_positions[m][n]=0

6.重新开始

点击重新开始,恢复棋盘。

def reload(self):if self.stop==1:self.stop=0self.canvas_bottom.delete('image')self.regretchance=0self.present=0self.create_pB()for m in range(1,self.mode_num+1):for n in range(1,self.mode_num+1):self.positions[m][n]=0self.last_3_positions[m][n]=0self.last_2_positions[m][n]=0self.last_1_positions[m][n]=0

7.右侧太极图的设置

def create_pW(self):self.pW=self.canvas_bottom.create_image(500*self.size+11, 65*self.size,image=self.photoW)self.canvas_bottom.addtag_withtag('image',self.pW)def create_pB(self):self.pB=self.canvas_bottom.create_image(500*self.size-11, 65*self.size,image=self.photoB)self.canvas_bottom.addtag_withtag('image',self.pB)def del_pW(self):self.canvas_bottom.delete(self.pW)def del_pB(self):self.canvas_bottom.delete(self.pB)

8.落子设置

def shadow(self,event):if not self.stop:# 找到最近格点,在当前位置靠近的格点出显示棋子图片,并删除上一位置的棋子图片if (20*self.size<event.x<380*self.size) and (20*self.size<event.y<380*self.size):dx=(event.x-20*self.size)%self.DDDy=(event.y-20*self.size)%self.ddself.cross=self.canvas_bottom.create_image(event.x-dx+round(dx/self.dd)*self.dd+22*self.p, event.y-dy+round(dy/self.dd)*self.dd-27*self.p,image=self.photoWBU_list[self.present])self.canvas_bottom.addtag_withtag('image',self.cross)if self.cross_last!=None:self.canvas_bottom.delete(self.cross_last)self.cross_last=self.cross# 落子,并驱动玩家的轮流下棋行为def getDown(self,event):if not self.stop:# 先找到最近格点if (20*self.size-self.dd*0.4<event.x<self.dd*0.4+380*self.size) and (20*self.size-self.dd*0.4<event.y<self.dd*0.4+380*self.size):dx=(event.x-20*self.size)%self.dddy=(event.y-20*self.size)%self.ddx=int((event.x-20*self.size-dx)/self.dd+round(dx/self.dd)+1)y=int((event.y-20*self.size-dy)/self.dd+round(dy/self.dd)+1)# 判断位置是否已经被占据if self.positions[y][x]==0:# 未被占据,则尝试占据,获得占据后能杀死的棋子列表self.positions[y][x]=self.present+1self.image_added=self.canvas_bottom.create_image(event.x-dx+round(dx/self.dd)*self.dd+4*self.p, event.y-dy+round(dy/self.dd)*self.dd-5*self.p,image=self.photoWBD_list[self.present])self.canvas_bottom.addtag_withtag('image',self.image_added)# 棋子与位置标签绑定,方便“杀死”self.canvas_bottom.addtag_withtag('position'+str(x)+str(y),self.image_added)deadlist=self.get_deadlist(x,y)self.kill(deadlist)# 判断是否重复棋局if not self.last_2_positions==self.positions:# 判断是否属于有气和杀死对方其中之一if len(deadlist)>0 or self.if_dead([[x,y]],self.present+1,[x,y])==False:# 当不重复棋局,且属于有气和杀死对方其中之一时,落下棋子有效if not self.regretchance==1:self.regretchance+=1else:self.regretButton['state']=NORMALself.last_3_positions=copy.deepcopy(self.last_2_positions)self.last_2_positions=copy.deepcopy(self.last_1_positions)self.last_1_positions=copy.deepcopy(self.positions)# 删除上次的标记,重新创建标记self.canvas_bottom.delete('image_added_sign')self.image_added_sign=self.canvas_bottom.create_oval(event.x-dx+round(dx/self.dd)*self.dd+0.5*self.dd, event.y-dy+round(dy/self.dd)*self.dd+0.5*self.dd,event.x-dx+round(dx/self.dd)*self.dd-0.5*self.dd, event.y-dy+round(dy/self.dd)*self.dd-0.5*self.dd,width=3,outline='#3ae')self.canvas_bottom.addtag_withtag('image',self.image_added_sign)self.canvas_bottom.addtag_withtag('image_added_sign',self.image_added_sign)if self.present==0:self.create_pW()self.del_pB()self.present=1else:self.create_pB()self.del_pW()self.present=0else:# 不属于杀死对方或有气,则判断为无气,警告并弹出警告框self.positions[y][x]=0self.canvas_bottom.delete('position'+str(x)+str(y))self.bell()self.showwarningbox('无气',"你被包围了!")else:# 重复棋局,警告打劫self.positions[y][x]=0self.canvas_bottom.delete('position'+str(x)+str(y))self.recover(deadlist,(1 if self.present==0 else 0))self.bell()self.showwarningbox("打劫","此路不通!")else:# 覆盖,声音警告self.bell()else:# 超出边界,声音警告self.bell()

9.吃子规则判定设置

def if_dead(self,deadList,yourChessman,yourPosition):for i in [-1,1]:if [yourPosition[0]+i,yourPosition[1]] not in deadList:if self.positions[yourPosition[1]][yourPosition[0]+i]==0:return Falseif [yourPosition[0],yourPosition[1]+i] not in deadList:if self.positions[yourPosition[1]+i][yourPosition[0]]==0:return Falseif ([yourPosition[0]+1,yourPosition[1]] not in deadList) and (self.positions[yourPosition[1]][yourPosition[0]+1]==yourChessman):midvar=self.if_dead(deadList+[[yourPosition[0]+1,yourPosition[1]]],yourChessman,[yourPosition[0]+1,yourPosition[1]])if not midvar:return Falseelse:deadList+=copy.deepcopy(midvar)if ([yourPosition[0]-1,yourPosition[1]] not in deadList) and (self.positions[yourPosition[1]][yourPosition[0]-1]==yourChessman):midvar=self.if_dead(deadList+[[yourPosition[0]-1,yourPosition[1]]],yourChessman,[yourPosition[0]-1,yourPosition[1]])if not midvar:return Falseelse:deadList+=copy.deepcopy(midvar)if ([yourPosition[0],yourPosition[1]+1] not in deadList) and (self.positions[yourPosition[1]+1][yourPosition[0]]==yourChessman):midvar=self.if_dead(deadList+[[yourPosition[0],yourPosition[1]+1]],yourChessman,[yourPosition[0],yourPosition[1]+1])if not midvar:return Falseelse:deadList+=copy.deepcopy(midvar)if ([yourPosition[0],yourPosition[1]-1] not in deadList) and (self.positions[yourPosition[1]-1][yourPosition[0]]==yourChessman):midvar=self.if_dead(deadList+[[yourPosition[0],yourPosition[1]-1]],yourChessman,[yourPosition[0],yourPosition[1]-1])if not midvar:return Falseelse:deadList+=copy.deepcopy(midvar)return deadList# 警告消息框,接受标题和警告信息def showwarningbox(self,title,message):self.canvas_bottom.delete(self.cross)tkinter.messagebox.showwarning(title,message)# 落子后,依次判断四周是否有棋子被杀死,并返回死棋位置列表def get_deadlist(self,x,y):deadlist=[]for i in [-1,1]:if self.positions[y][x+i]==(2 if self.present==0 else 1) and ([x+i,y] not in deadlist):killList=self.if_dead([[x+i,y]],(2 if self.present==0 else 1),[x+i,y])if not killList==False:deadlist+=copy.deepcopy(killList)if self.positions[y+i][x]==(2 if self.present==0 else 1) and ([x,y+i] not in deadlist):killList=self.if_dead([[x,y+i]],(2 if self.present==0 else 1),[x,y+i])if not killList==False:deadlist+=copy.deepcopy(killList)return deadlist# 恢复位置列表list_to_recover为b_or_w指定的棋子def recover(self,list_to_recover,b_or_w):if len(list_to_recover)>0:for i in range(len(list_to_recover)):self.positions[list_to_recover[i][1]][list_to_recover[i][0]]=b_or_w+1self.image_added=self.canvas_bottom.create_image(20*self.size+(list_to_recover[i][0]-1)*self.dd+4*self.p, 20*self.size+(list_to_recover[i][1]-1)*self.dd-5*self.p,image=self.photoWBD_list[b_or_w])self.canvas_bottom.addtag_withtag('image',self.image_added)self.canvas_bottom.addtag_withtag('position'+str(list_to_recover[i][0])+str(list_to_recover[i][1]),self.image_added)# 杀死位置列表killList中的棋子,即删除图片,位置值置0def kill(self,killList):if len(killList)>0:for i in range(len(killList)):self.positions[killList[i][1]][killList[i][0]]=0self.canvas_bottom.delete('position'+str(killList[i][0])+str(killList[i][1]))

10.其他

退出游戏和全局变量的说明。

def keyboardQuit(self,event):self.quit()# 以下两个函数修改全局变量值,newApp使主函数循环,以建立不同参数的对象def newGame1(self):global mode_num,newAppmode_num=(13 if self.mode_num==9 else 9)newApp=Trueself.quit()def newGame2(self):global mode_num,newAppmode_num=(13 if self.mode_num==19 else 19)newApp=Trueself.quit()# 声明全局变量,用于新建Application对象时切换成不同模式的游戏global mode_num,newAppmode_num=9newApp=False

11.程序入口

if __name__=='__main__':    # 循环,直到不切换游戏模式    while True:        newApp=False        app=Application(mode_num)        app.title('围棋')        app.mainloop()        if newApp:            app.destroy()        else:            break

12.效果图

基于Python如何实现围棋游戏

到此,相信大家对“基于Python如何实现围棋游戏”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 基于Python如何实现围棋游戏

本文链接: https://lsjlt.com/news/330046.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 基于Python如何实现围棋游戏
    本篇内容主要讲解“基于Python如何实现围棋游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“基于Python如何实现围棋游戏”吧!1.导入模块tkinter:ttk覆盖tkinter部分对象...
    99+
    2023-06-30
  • 基于Python实现围棋游戏的示例代码
    目录1.导入模块2.初始化棋盘3. 开始游戏4.放弃当前回合落子5.悔棋判断6.重新开始7.右侧太极图的设置8.落子设置9.吃子规则判定设置10.其他11.程序入口12.效果图文件自...
    99+
    2024-04-02
  • 基于Python实现五子棋游戏
    本文实例为大家分享了Python实现五子棋游戏的具体代码,供大家参考,具体内容如下 了解游戏的规则是我们首先需要做的事情,如果不知晓规则,那么我们肯定寸步难行。 五子棋游戏规则: 1...
    99+
    2024-04-02
  • C#实现围棋游戏
    本文实例为大家分享了C#实现围棋游戏的具体代码,供大家参考,具体内容如下 之所以选择围棋作为大作业一方面是想挑战一下,另一方面是由于从6岁学围棋到11岁放下,再到今天已将近8年了,也...
    99+
    2024-04-02
  • 基于Python如何实现有趣的象棋游戏
    本篇内容主要讲解“基于Python如何实现有趣的象棋游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“基于Python如何实现有趣的象棋游戏”吧!一、游戏介绍中国象棋游戏是一款怡神益智有益身心的...
    99+
    2023-07-05
  • python实现一个围棋小游戏
    一道Python课作业题,大致如下: 编写一个类: 该类Building应具有以下方法: ●一个构造函数,它根本不接受任何参数(除了通常的`self`) ●setHeightRand...
    99+
    2022-11-13
    python围棋程序 python围棋算法
  • 基于Python实现有趣的象棋游戏
    目录导语一、游戏介绍二、游戏规则三、环境准备四、代码展示五、效果展示导语 一直以来,中国象棋都是中华民族的一种象征,当然也是人们最为喜感的一种娱乐方式。 在若干年前,人们都习惯于约上...
    99+
    2023-03-06
    Python实现象棋游戏 Python象棋游戏 Python象棋 Python游戏
  • 基于jquery实现五子棋游戏
    本文实例为大家分享了jquery实现五子棋游戏的具体代码,供大家参考,具体内容如下 花了一天时间完成一个简单五子棋游戏(非人机) html: <!DOCTYPE html>...
    99+
    2024-04-02
  • 基于C语言如何实现钻石棋游戏
    这篇文章主要介绍了基于C语言如何实现钻石棋游戏的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇基于C语言如何实现钻石棋游戏文章都会有所收获,下面我们一起来看看吧。游戏规则这是一个单人钻石棋游戏,游戏中有两种颜色的...
    99+
    2023-07-05
  • 基于flask实现五子棋小游戏
    本文实例为大家分享了基于flask实现五子棋小游戏的具体代码,供大家参考,具体内容如下 前言 首先说明一下,本人方向是java后端,只因老师布置了一个作业,要用flask来做一个五子...
    99+
    2024-04-02
  • 基于C++实现五子棋小游戏
    本文实例为大家分享了C++实现五子棋小游戏的具体代码,供大家参考,具体内容如下  (这是一个颜色会变化的呦) #include <iostream> usi...
    99+
    2024-04-02
  • 基于C语言实现三子棋游戏
    说到三子棋,我想大家一定不陌生吧,它也是我童年中的一部分,今天我们用C语言来实现一下简易版的三子棋。 首先,介绍一下游戏规则: 1.在一个九宫格上进行下棋; 2.玩家两名,双方先后落...
    99+
    2024-04-02
  • 基于C语言实现井字棋游戏
    井字棋游戏要求在3乘3棋盘上,每行都相同或者每列都相同再或者对角线相同,则胜出.因此我们可以使用一个二维数组来表示棋盘,判断胜负只需要判断数组元素是否相同即可.具体我们可以分为以下几...
    99+
    2024-04-02
  • python如何实现三子棋游戏
    本文小编为大家详细介绍“python如何实现三子棋游戏”,内容详细,步骤清晰,细节处理妥当,希望这篇“python如何实现三子棋游戏”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、基本流程三子棋游戏实现逻辑如下...
    99+
    2023-07-06
  • 基于Java实现马踏棋盘游戏算法
    马踏棋盘很好实现,但有时运行起来特别慢,还可能出不来结果,最常用的就是深度优先遍历+回溯,相信大家都学过数据结构,对图的深度遍历都有了解,下面就是代码的实现,如果对代码理解有困难,可...
    99+
    2024-04-02
  • 基于JS实现经典的井字棋游戏
    目录先看成品游戏初始化界面:玩家获胜AI电脑获胜思路生成棋盘重新开始玩家落子电脑落子代码HTMLCSSjs井字棋作为我们在上学时代必玩的一款连珠游戏,你知道如何做到先手必然不会输吗?...
    99+
    2024-04-02
  • 基于C语言实现三子棋小游戏
    在写三子棋之前,我们要先了解三子棋的一个大概的图形,以便于我们整理思路。          ...
    99+
    2024-04-02
  • python实现象棋游戏
    本文实例为大家分享了python实现象棋游戏的具体代码,供大家参考,具体内容如下 import math from turtle import * speed(0)   #调整画的...
    99+
    2024-04-02
  • 基于Python怎么实现人机对战五子棋游戏
    人人对战游戏规则:p1为黑子,p2为白子,黑子先手,一方达到五子相连即为获胜。动态演示源码分享cheackboard.py定义黑白子,落子位置以及获胜规则。from collections import namedtuple Chessm...
    99+
    2023-05-20
    Python
  • 基于Python如何实现格斗小游戏
    本文小编为大家详细介绍“基于Python如何实现格斗小游戏”,内容详细,步骤清晰,细节处理妥当,希望这篇“基于Python如何实现格斗小游戏”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、简易版本格斗impor...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作