1. 游戏思路和流程图

实现功能:船只在可以在大海上移动打捞宝藏,船只可以扫描1格范围内的宝藏(后续难度,可以调整扫描范围,可以调整前进的格数)

游戏流程图

2. 使用模块和游戏提示

import random
ships_coordinates={} #船只坐标
def game_info():
'''游戏提示'''
print('欢迎来到船只寻宝游戏')
print('W(上) A(左) S(下) D(右) 来移动')
print('船(B)的探测范围是一格,移动次数为九次')

3. 双选验证

def Double_choice(a,b,hint):
'''双选择验证函数
:param a 第一个选项值
:param b 第二个选项值
:param hint 选项信息
:return 返回输入值'''
choice=''
while choice.lower() !=a and choice.lower() !=b:
print(hint)
choice=input()
return choice

4. 用户输入验证

def letter_move_judge(letter,map_x,map_y):
'''移动字母限制
:param letter 用户输入字母
:param map_x 地图x坐标
:param map_y 地图y坐标
:param 返回用户输入字符'''
ships_x=ships_coordinates['x']
ships_y =ships_coordinates['y']
while True:
if len(letter)!=1:
print('请输入一个字母')
elif letter.lower() not in 'w a s d':
print('请输入W or A or S or D')
else:
if letter.lower()=='w' and ships_y-1 <0:
print('超过界限了')
elif letter.lower()=='a' and ships_x-1 <0:
print('超过界限了')
elif letter.lower()=='s' and ships_y+1 >map_y-1:
print(ships_coordinates['y']-1)
print('超过界限了')
elif letter.lower()=='d' and ships_x+1 >map_x-1:
print('超过界限了')
else:
break
letter=input()
return letter.lower()

5. 海水列表

def get_seawater(x,y):
'''生成海水列表
:param x 每列的行数
:param y 行数
:return 返回海水列表'''
seawater_map=[['~' for i in range(x)] for j in range(y)]
return seawater_map

6. 宝藏坐标列表

def treasure_location(x,y):
'''随机宝藏坐标
:param x 每列的行数
:param y 行数
:return 返回宝藏列表'''
treasure_list=[]
count=5
while count:
treasure_x=random.randint(0,x-1)
treasure_y = random.randint(0, y-1)
if (treasure_x,treasure_y) not in treasure_list:
treasure_list.append((treasure_x,treasure_y))
count-=1
return treasure_list

7.  海水界面显示

def seawater_info(seawater_map):
'''打印海水
:param seawater_map 海水列表'''
for i in seawater_map:
print(' '.join(i))

8. 初始化游戏开始船只位置

def restarting_init(seawater_map):
'''初始化船只的位置'''
x=ships_coordinates['x']
y=ships_coordinates['y']
seawater_map[y][x]='B'
return seawater_map

9.  扫描船只范围内宝藏

def treasure_tab(treasure_list,seawater_map):
'''宝藏标记
:param treasure_list 宝藏位置列表
:param seawater_map 海水地图
:return 返回海水地图'''
ships_x=ships_coordinates['x']
ships_y=ships_coordinates['y']
treasure='$'
scope=1 #扫描格数需要改良
for i in range(1,scope+1):
if (ships_x-i, ships_y) in treasure_list:
seawater_map[ships_y][ships_x - i]=treasure if (ships_x-i,ships_y+i) in treasure_list:
seawater_map[ships_y + i][ships_x - i] = treasure if (ships_x-i, ships_y - i) in treasure_list:
seawater_map[ships_y-i][ships_x - i] = treasure if (ships_x + i, ships_y) in treasure_list:
seawater_map[ships_y][ships_x + i] = treasure if (ships_x+i,ships_y+i) in treasure_list:
seawater_map[ships_y+i][ships_x + i] = treasure if (ships_x+i,ships_y-i) in treasure_list:
seawater_map[ships_y-i][ships_x + i] = treasure if (ships_x, ships_y +i) in treasure_list:
seawater_map[ships_y+i][ships_x] = treasure
if (ships_x, ships_y - i) in treasure_list:
seawater_map[ships_y-i][ships_x] = treasure
return seawater_map

10.  判断船只地点是否有宝藏

def treasure_judge(treasure_list):
'''判断坐标是否有宝藏
:param treasure_list 宝藏地图
:return True 代表此地有宝藏'''
if (ships_coordinates['x'], ships_coordinates['y']) in treasure_list:
return True
return False

11.  移动船只

def restarting(ships_remove,seawater_map):
'''改变船的坐标
:param ships_remove 移动的位置
:param seawater_map 海水地图'''
ships_x=ships_coordinates['x']
ships_y=ships_coordinates['y']
number=1
seawater_map[ships_y][ships_x]='~'
if ships_remove=='w':
ships_y-=1
elif ships_remove=='a':
ships_x-=1
elif ships_remove=='s':
ships_y += 1
elif ships_remove=='d':
ships_x += 1
seawater_map[ships_y][ships_x] = 'B'
ships_coordinates['x']=ships_x
ships_coordinates['y']=ships_y
return seawater_map

12.  游戏核心

def game_start():
'''游戏核心'''
map_x=9
map_y=5
ships_coordinates['x']=map_x // 2
ships_coordinates['y'] = map_y // 2
treasure_count=0
count=9
seawater_map=get_seawater(map_x,map_y)
treasure_list=treasure_location(map_x,map_y)
seawater_map=restarting_init(seawater_map)
while count:
if treasure_judge(treasure_list):
treasure_count+=1
treasure_list.remove((ships_coordinates['x'],ships_coordinates['y']))
print('成功打捞宝藏..(%d个)'%treasure_count)
if treasure_count==5:
break
seawater_map=treasure_tab(treasure_list,seawater_map)
seawater_info(seawater_map)
print('请输入移动的位置(机会%d)'%count)
ships_remove=letter_move_judge(input(),map_x,map_y)
seawater_map=restarting(ships_remove,seawater_map)
count -= 1
seawater_info(seawater_map)
if count:
print('你寻找到了所有宝藏,提前结束了寻宝,今天收获%d个宝藏'%treasure_count)
else:
print('天黑了船只返回了船坞,今天收获%d个宝藏'%treasure_count)
#结束条件宝藏打捞完毕或次数用光

13. 游戏外壳

def game_shell():
'''外壳程序'''
game_info() # 游戏开始提示
game_start()
while True:
message='你想在玩一次吗(Y or N)'
again_flag=Double_choice('y','n',message)
if again_flag=='n':
break
game_start()

14. 运行游戏

game_shell()

python学习途径

本游戏参考书本 <<Python游戏编程快速上手>>

友情推荐:  猿人学Python【https://www.yuanrenxue.com/】 由一群工作十余年的老程序员结合实际工作经验所写的Python教程。

python 游戏(船只寻宝)的更多相关文章

  1. Python游戏编程入门

    <Python游戏编程入门>这些文章负责整理在这本书中的知识点.注意事项和课后习题的尝试实现.并且对每一个章节给出的最终实例进行分析和注释. 初识pygame:pie游戏pygame游戏库 ...

  2. python 游戏 —— 汉诺塔(Hanoita)

    python 游戏 —— 汉诺塔(Hanoita) 一.汉诺塔问题 1. 问题来源 问题源于印度的一个古老传说,大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆 ...

  3. Python 游戏之旅(Pygame)

    Pygame是跨平台Python模块,专为电子游戏设计,包含图像.声音.建立在SDL基础上,允许实时电子游戏研发而无需被低级语言(如机器语言和汇编语言)束缚.基于这样一个设想,所有需要的游戏功能和理念 ...

  4. python 游戏(数字推理游戏Bagels)

    1.游戏思路和流程图 实现功能:玩家猜测三位不一样的数字,猜错了有提示,提示分别为(位置错误数字正确),(位置和数字正确),(数字和位置都不正确) 游戏流程图 2. 使用模块和游戏提示 import ...

  5. python 游戏(井字棋)

    1. 游戏思路和流程图 实现功能,现实生活中的井字棋玩法 游戏流程图 2. 使用模块和游戏提示 import random def game_info(): print('欢迎来到井字棋游戏') pr ...

  6. python 游戏(猜单词Hangman)

    1.游戏思路和流程图 实现功能:随机一个单词让玩家猜测(后续难度实现修改为成语填空,成语必须要有提示,可修改猜的次数,增加连续猜成语,难度系数随着次数的增加而增加) 游戏流程图 2. 单词库和模块 i ...

  7. python 游戏(龙的国度)

    1. 理清楚游戏思路 实现功能:2个洞穴选择,一个洞穴是好龙,一个洞穴是坏龙,坏龙可以概率屠龙或者概率逃跑选项(后续难度需要增加宝藏获取装备,随机遇见商人,随着游戏进度逐步减少屠龙概率) 2. 计数和 ...

  8. python 游戏(猜数字)

    1. 构造猜数字核心函数 import random def guess_core(guess_min,guess_max,guess_counrt): '''猜数字核心判断函数 :param gue ...

  9. Python游戏引擎开发(七):绘制矢量图

    今天来完毕绘制矢量图形. 没有读过前几章的同学,请先阅读前几章: Python游戏引擎开发(一):序 Python游戏引擎开发(二):创建窗体以及重绘界面 Python游戏引擎开发(三):显示图片 P ...

随机推荐

  1. 乘风破浪:LeetCode真题_024_Swap Nodes in Pairs

    乘风破浪:LeetCode真题_024_Swap Nodes in Pairs 一.前言 这次还是链表的操作,不过我们需要交换链表奇数和偶数位置上的节点,因此要怎么做呢? 二.Swap Nodes i ...

  2. 3.1Python的判断选择语句

    返回总目录 目录: 1.if单分支语句 2.if else 双分支语句 3.if elif ...else多分支语句 4.if 嵌套语句 判断语句总览: (一)if单分支语句: 语法: if 条件: ...

  3. django复习-3-请求与响应

    一.请求request 前端向后端传递参数有几种方式? 提取URL的特定部分,如/weather/beijing/2018,可以在服务器端的路由中用正则表达式截取: "http://127. ...

  4. 数据结构习题Pop Sequence的理解----小白笔记^_^

    Pop Sequence(25 分) Given a stack which can keep M numbers at most. Push N numbers in the order of 1, ...

  5. node封装mysql操作

    前言 node是基于异步的,因此在进行数据库查询操作的通常是通过回调来操作查询结果.但是在有了es7的async/await,基本不再需要回调了,所以本篇是基于async/await对mysql进行一 ...

  6. 难度并不NOIP的NOIP模拟赛

    今天老师请了前几届的学长来讲课,可是讲课为什么要考试呢... 学长说难度是NOIP,于是我就naive的跟着参加了,然而T3难度并不友好,感觉确实不是很适合我们现在做......不过课本来也不是给我们 ...

  7. 1008. [HNOI2008]越狱【快速幂】

    Description 监狱有连续编号为1...N的N个房间,每个房间关押一个犯人,有M种宗教,每个犯人可能信仰其中一种.如果 相邻房间的犯人的宗教相同,就可能发生越狱,求有多少种状态可能发生越狱 I ...

  8. MetaMask/provider-engine-2-代码

    package.json "main": "index.js", "scripts": { "test": " ...

  9. javascript仿新浪微博图片放大缩小及旋转效果

    javascript仿新浪微博图片放大缩小及旋转效果 经常看到新浪微博里有图片放大缩小旋转效果,感觉效果还不错,所以就想试着做一个类似的demo出来,至于旋转对于IE可以用滤镜来解决,标准的浏览器可以 ...

  10. Python2.7-filecmp

    filecmp 模块,定义了比较文件或目录的函数,比较文件只会有 True 和 False 两种结果,比较目录会返回目录下相同的文件,不同的文件,出错的文件.比较文件也可以用 difflib 模块,d ...