简单的贪吃蛇游戏代码_python 贪吃蛇

简单的贪吃蛇游戏代码_python 贪吃蛇Python贪吃蛇游戏编写代码来源:中文源码网浏览:次日期:2018年9月2日【下载文档:Python贪吃蛇游戏编写代码.txt】(友情提示:右键点上行txt文档名->目标另存为)Python贪吃蛇游戏编写代码最近在学Python,想做点什么来练练手,命令行的贪吃蛇一般是C的练手项目,但是一时之间找不到别的,就先做个贪吃蛇来练练简单的语法。由于…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

Python贪吃蛇游戏编写代码

来源:中文源码网    浏览: 次    日期:2018年9月2日

【下载文档:  Python贪吃蛇游戏编写代码.txt 】

(友情提示:右键点上行txt文档名->目标另存为)

Python贪吃蛇游戏编写代码 最近在学Python,想做点什么来练练手,命令行的贪吃蛇一般是C的练手项目,但是一时之间找不到别的,就先做个贪吃蛇来练练简单的语法。

由于Python监听键盘很麻烦,没有C语言的kbhit(),所以这条贪吃蛇不会自己动,运行效果如下:要求:用#表示边框,用*表示食物,o表示蛇的身体,O表示蛇头,使用wsad来移动

Python版本:3.6.1

系统环境:Win10

类:

board:棋盘,也就是游戏区域

snake:贪吃蛇,通过记录身体每个点来记录蛇的状态

game:游戏类

本来还想要个food类的,但是food只需要一个坐标,和一个新建,所以干脆使用list来保存坐标,新建food放在game里面,从逻辑上也没有太大问题

源码:

# Write By Guobao

# 2017/4//7

#

# 贪吃蛇

# 用#做边界,*做食物,o做身体和头部

# python 3.6.1import copy

import random

import os

import msvcrt# the board class, used to put everything

class board: __points =[] def __init__(self):

self.__points.clear()

for i in range(22):

line = []

if i == 0 or i == 21:

for j in range(22):

line.append(‘#’)

else:

line.append(‘#’)

for j in range(20):

line.append(‘ ‘)

line.append(‘#’)

self.__points.append(line) def getPoint(self, location):

return self.__points[location[0]][location[1]] def clear(self):

self.__points.clear()

for i in range(22):

line = []

if i == 0 or i == 21:

for j in range(22):

line.append(‘#’)

else:

line.append(‘#’)

for j in range(20):

line.append(‘ ‘)

line.append(‘#’)

self.__points.append(line) def put_snake(self, snake_locations):

# clear the board

self.clear() # put the snake points

for x in snake_locations:

self.__points[x[0]][x[1]] = ‘o’ # the head

x = snake_locations[len(snake_locations) – 1]

self.__points[x[0]][x[1]] = ‘O’ def put_food(self, food_location):

self.__points[food_location[0]][food_location[1]] = ‘*’ def show(self):

os.system(“cls”)

for i in range(22):

for j in range(22):

print(self.__points[i][j], end=”)

print()# the snake class

class snake:

__points = [] def __init__(self):

for i in range(1, 6):

self.__points.append([1, i]) def getPoints(self):

return self.__points # move to the next position

# give the next head

def move(self, next_head):

self.__points.pop(0)

self.__points.append(next_head) # eat the food

# give the next head

def eat(self, next_head):

self.__points.append(next_head) # calc the next state

# and return the direction

def next_head(self, direction=’default’): # need to change the value, so copy it

head = copy.deepcopy(self.__points[len(self.__points) – 1]) # calc the “default” direction

if direction == ‘default’:

neck = self.__points[len(self.__points) – 2]

if neck[0] > head[0]:

direction = ‘up’

elif neck[0] < head[0]:

direction = ‘down’

elif neck[1] > head[1]:

direction = ‘left’

elif neck[1] < head[1]:

direction = ‘right’ if direction == ‘up’:

head[0] = head[0] – 1

elif direction == ‘down’:

head[0] = head[0] + 1

elif direction == ‘left’:

head[1] = head[1] – 1

elif direction == ‘right’:

head[1] = head[1] + 1

return head# the game

class game: board = board()

snake = snake()

food = []

count = 0 def __init__(self):

self.new_food()

self.board.clear()

self.board.put_snake(self.snake.getPoints())

self.board.put_food(self.food) def new_food(self):

while 1:

line = random.randint(1, 20)

column = random.randint(1, 20)

if self.board.getPoint([column, line]) == ‘ ‘:

self.food = [column, line]

return def show(self):

self.board.clear()

self.board.put_snake(self.snake.getPoints())

self.board.put_food(self.food)

self.board.show()

def run(self):

self.board.show() # the ‘w a s d’ are the directions

operation_dict = {b’w’: ‘up’, b’W’: ‘up’, b’s’: ‘down’, b’S’: ‘down’, b’a’: ‘left’, b’A’: ‘left’, b’d’: ‘right’, b’D’: ‘right’}

op = msvcrt.getch() while op != b’q’:

if op not in operation_dict:

op = msvcrt.getch()

else:

new_head = self.snake.next_head(operation_dict[op]) # get the food

if self.board.getPoint(new_head) == ‘*’:

self.snake.eat(new_head)

self.count = self.count + 1

if self.count >= 15:

self.show()

print(“Good Job”)

break

else:

self.new_food()

self.show() # 反向一Q日神仙

elif new_head == self.snake.getPoints()[len(self.snake.getPoints()) – 2]:

pass # rush the wall

elif self.board.getPoint(new_head) == ‘#’ or self.board.getPoint(new_head) == ‘o’:

print(‘GG’)

break # normal move

else:

self.snake.move(new_head)

self.show()

op = msvcrt.getch()game().run()笔记:

1.Python 没有Switch case语句,可以利用dirt来实现

2.Python的=号是复制,复制引用,深复制需要使用copy的deepcopy()函数来实现

3.即使在成员函数内,也需要使用self来访问成员变量,这和C++、JAVA很不一样

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持中文源码网。

亲,试试微信扫码分享本页! *^_^*

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169540.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 集群软件的分类「建议收藏」

    集群软件的分类「建议收藏」集群软件的分类   在现在存储环境中,集群软件是一个很重要的模块。然而,很多人不清楚集群软件的分类,不知道oracle的RAC,IBM的HACMP,Symantec的VCS和EMC的AutoStart,甚至一些用户写的脚本,分别属于哪一类,它们之间有什么相同和不同的地方:   一般来讲,集群软件根据侧重的方向和试图解决的问题,分为三大类:高性能集群(Highperforma

    2022年10月16日
    0
  • ES[7.6.x]学习笔记(七)IK中文分词器

    ES[7.6.x]学习笔记(七)IK中文分词器

    2020年11月14日
    188
  • 关于数据库读写分离

    1、what读写分离读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。2、why那么为什么要读写分离呢?因为数据库的“写”(写10000条数据到oracle可能要3分钟)操作是比较耗时的。但是数据库的“读”(从oracle读…

    2022年4月6日
    39
  • webpack基本配置项_webpack配置文件详解

    webpack基本配置项_webpack配置文件详解前言上篇我们已经配置好了本地开发服务器,但是配置的相对比较凌乱,一个文件中有些是开发时用到的配置,有些是生成时用到的配置,有些是开发和生成都要用到的配置,所以我们这里把环境分为3个环境webpac

    2022年8月7日
    8
  • python每天定时9点执行_python定时执行方法

    python每天定时9点执行_python定时执行方法1time.sleepimporttimeforiinrange(5):print(i)time.sleep(10)2用shedimporttimeimportschedschedule=sched.scheduler(time.time,time.sleep)deffunc(string1,float1):print(“nowis”,time.time(),”…

    2022年7月17日
    23
  • 参考平面及其高度_某层平面图的剖切位置高度一般是离该层地面1.0米–求规范出处…

    参考平面及其高度_某层平面图的剖切位置高度一般是离该层地面1.0米–求规范出处…某层平面图的剖切位置高度一般是离该层地面1.0米–求规范出处通气孔,图内应包括剖切面及投影方向可见的建筑构造以及必要的尺寸,如需表示高窗、洞口、标高等没有规范规定剖切高度一般来说剖切高度是1500左右吧人视线位置可以剖到正常高度的门窗洞口建筑制图标准GB/T50104—20014.1.4建筑物平面图应在建筑物的门窗洞口处水平剖切俯视(屋顶平面图应在屋面以上俯视)、槽一般情况下都…

    2022年5月9日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号