python五子棋游戏的设计与实现
作者:橘子女侠 时间:2021-04-19 07:17:43
这个python的小案例是五子棋游戏的实现,在这个案例中,我们可以实现五子棋游戏的两个玩家在指定的位置落子,画出落子后的棋盘,并且根据函数判断出输赢的功能。
这个案例的思路如下所示:
首先,根据棋盘的样子画出棋盘
然后,对棋盘进行初始化,将可以落子的位置进行统一化处理
接下来,就是进入游戏的环节,双方轮流落子,落子后,并将棋盘画出
最后,根据落子的位置判断选手的的输赢情况,游戏结束
五子棋游戏的设计和实现
代码如下:
def main():
print("五子棋游戏".center(50,'='))
guige=int(input("请输入棋盘的规格:"))
#按照五子棋的棋盘样式,画出棋盘
print_init(guige)
# 初始化棋盘
wzq = {}
for i in range(1, guige + 1):
for j in range(1, guige + 1):
wzq[(i, j)] = "+"
#重画棋盘
reprint(guige,wzq)
#按照五子棋的棋盘样式,画出棋盘
def print_init(guige):
#打印出首行的棋盘列
for i in range(guige):
print("%4d"%(i+1),end='')
print()
#双重循环,第一重为棋盘的行,隔一行输出棋盘的行数
for i in range(guige*2-1):
#打印出类似 “1 +---+---+---+---+---+”,行号,+,—
if(i%2==0):
print("%-3d"%((i+2)/2),end='')
#第二重循环,为棋盘的列,主要在于找出对应位置显示的内容
for j in range(guige * 4 - 3):
if (j % 4 == 0):
print("+", end='')
else:
print("-", end='')
#打印出类似“ | | | | | |”
else:
print("%3s"%' ',end='')
for j in range(guige*4-3):
if(j%4==0):
print("|",end='')
else:
print(" ",end='')
#每行输出完成之后换行
print()
#重画棋盘,对双方下子进行重画
def reprint(guige,wzq):
for i in range(guige*guige) :
if i % 2 == 0:
xuanshou = "X"
else:
xuanshou = "O"
# 双方轮流下棋
while 1:
print("现在轮到%s方落子" % xuanshou)
position = input("请输入落子位置:")
x_position = int(position.split()[0])
y_position = int(position.split()[1])
#判断输入的位置是否有子,有子一直输入,直到输入的位置无子
if wzq[(x_position, y_position)] in ["X", "O"]:
print("您输入的位置有子,请重新输入!")
else:
break
if wzq[(x_position, y_position)]=="+":
#重画棋盘
wzq[(x_position, y_position)] = xuanshou
for i in range(guige):
print("%4d"%(i+1),end='')
print()
for i in range(guige*2-1):
if(i%2==0):
print("%-3d"%((i+2)/2),end='')
for j in range(guige * 4 - 3):
if (j % 4 == 0):
x=(i+2)/2
y=j/4+1
print(wzq[(x,y)],end='')
else:
print("-", end='')
else:
print("%3s"%' ',end='')
for j in range(guige*4-3):
if(j%4==0):
print("|",end='')
else:
print(" ",end='')
print()
else:
isture=True
print("您输入的位置已经有子,请重新输入!")
# 判断输赢
# 第一种情况
wzq_win1(wzq,guige,xuanshou)
# 第二种情况
wzq_win2(wzq,guige,xuanshou)
# 第三种情况
wzq_win3(wzq,guige,xuanshou)
# 第四种情况
wzq_win4(wzq,guige,xuanshou)
else:
print("游戏结束,平局!")
# 判断输赢
def wzq_win1(wzq,guige,xuanshou):
# 第一种输赢情况
for i in range(1, guige + 1):
for j in range(1, guige - 3):
if (wzq[(i, j)] == wzq[(i, j + 1)] == wzq[(i, j + 2)] == wzq[(i, j + 3)] == wzq[(i, j + 4)] and wzq[(i, j)] in ["X", "O"]):
print("%s获胜,游戏结束!" % xuanshou)
exit()
def wzq_win2(wzq,guige,xuanshou):
# 第二种输赢情况
for i in range(1, guige - 3):
for j in range(1, guige + 1):
if (wzq[(i, j)] == wzq[(i + 1, j)] == wzq[(i + 2, j)] == wzq[(i + 3, j)] == wzq[(i + 4, j)] and wzq[(i, j)] in ["X", "O"]):
print("%s获胜,游戏结束!" % xuanshou)
exit()
def wzq_win3(wzq,guige,xuanshou):
# 第三种输赢情况
for i in range(1, guige - 3):
for j in range(1, guige - 3):
if (wzq[(i, j)] == wzq[(i + 1, j + 1)] == wzq[(i + 2, j + 2)] == wzq[(i + 3, j + 3)] == wzq[(i + 4, j + 4)] and wzq[(i, j)] in ["X", "O"]):
print("%s获胜,游戏结束!" % xuanshou)
exit()
def wzq_win4(wzq, guige, xuanshou):
# 第四种输赢情况
for i in range(1, guige - 3):
for j in range(5, guige + 1):
if (wzq[(i, j)] == wzq[(i +1, j - 1)] == wzq[(i + 2, j - 2)] == wzq[(i + 3, j - 3)] == wzq[(i + 4, j - 4)] and wzq[(i, j)] in ["X", "O"]):
print("%s获胜,游戏结束!" % xuanshou)
exit()
main()
结果如下:
======================五子棋游戏=======================
请输入棋盘的规格:8
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---+---+---+---+---+
| | | | | | | |
5 +---+---+---+---+---+---+---+
| | | | | | | |
6 +---+---+---+---+---+---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到X方落子
请输入落子位置:5 5
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---+---+---+---+---+
| | | | | | | |
5 +---+---+---+---X---+---+---+
| | | | | | | |
6 +---+---+---+---+---+---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到O方落子
请输入落子位置:6 1
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---+---+---+---+---+
| | | | | | | |
5 +---+---+---+---X---+---+---+
| | | | | | | |
6 O---+---+---+---+---+---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到X方落子
请输入落子位置:4 4
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---+---X---+---+---+
| | | | | | | |
6 O---+---+---+---+---+---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到O方落子
请输入落子位置:5 4
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---+---+---+
| | | | | | | |
6 O---+---+---+---+---+---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到X方落子
请输入落子位置:6 6
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---+---+---+
| | | | | | | |
6 O---+---+---+---+---X---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到O方落子
请输入落子位置:6 5
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---+---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---+---+---+
| | | | | | | |
6 O---+---+---+---O---X---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到X方落子
请输入落子位置:3 3
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---X---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---+---+---+
| | | | | | | |
6 O---+---+---+---O---X---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到O方落子
请输入落子位置:5 6
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---+---+---+---+---+---+---+
| | | | | | | |
3 +---+---X---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---O---+---+
| | | | | | | |
6 O---+---+---+---O---X---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
现在轮到X方落子
请输入落子位置:2 2
1 2 3 4 5 6 7 8
1 +---+---+---+---+---+---+---+
| | | | | | | |
2 +---X---+---+---+---+---+---+
| | | | | | | |
3 +---+---X---+---+---+---+---+
| | | | | | | |
4 +---+---+---X---+---+---+---+
| | | | | | | |
5 +---+---+---O---X---O---+---+
| | | | | | | |
6 O---+---+---+---O---X---+---+
| | | | | | | |
7 +---+---+---+---+---+---+---+
| | | | | | | |
8 +---+---+---+---+---+---+---+
X获胜,游戏结束!
来源:https://blog.csdn.net/qq_38684504/article/details/85393285
标签:python,五子棋,游戏
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Pandas数据集的分块读取的实现
2021-02-03 07:52:24
![](https://img.aspxhome.com/file/2023/3/117973_0s.jpg)
在Python中使用成员运算符的示例
2023-12-12 01:36:20
![](https://img.aspxhome.com/file/2023/2/133672_0s.jpg)
基于python的Paxos算法实现
2023-04-15 07:40:58
![](https://img.aspxhome.com/file/2023/4/107034_0s.png)
Python面经之16个高频面试问题总结
2022-09-10 18:36:33
python使用pygame实现笑脸乒乓球弹珠球游戏
2021-07-26 09:49:47
![](https://img.aspxhome.com/file/2023/3/87473_0s.jpg)
互联网产品设计师自我介绍
2009-04-16 12:45:00
Python实现Socket通信建立TCP反向连接
2023-11-13 04:20:19
![](https://img.aspxhome.com/file/2023/9/86419_0s.jpg)
Python实现数据可视化看如何监控你的爬虫状态【推荐】
2022-07-15 11:50:43
![](https://img.aspxhome.com/file/2023/0/103190_0s.jpg)
利用python脚本如何简化jar操作命令
2021-02-12 11:08:15
举例讲解Python面向对象编程中类的继承
2022-02-09 02:59:14
使用Python发送各种形式的邮件的方法汇总
2022-12-21 15:24:46
在Python中移动目录结构的方法
2022-08-04 20:48:47
pandas温差查询案例的实现
2023-07-16 07:56:15
Oracle 创建监控账户 提高工作效率
2009-10-14 11:47:00
![](https://img.aspxhome.com/file/UploadPic/200910/14/20091014121213816.jpg)
Datawhale练习之二手车价格预测
2022-02-04 21:35:56
![](https://img.aspxhome.com/file/2023/6/126936_0s.png)
用伪类:hover实现提示效果
2008-05-29 12:59:00
python 如何将带小数的浮点型字符串转换为整数
2021-04-24 01:35:51
Python机器学习NLP自然语言处理基本操作关键词
2023-11-09 05:51:31
![](https://img.aspxhome.com/file/2023/9/63549_0s.gif)
解决在keras中使用model.save()函数保存模型失败的问题
2021-09-12 17:32:41
Django框架静态文件处理、中间件、上传文件操作实例详解
2021-03-07 14:31:04
![](https://img.aspxhome.com/file/2023/0/68890_0s.png)