贪吃蛇编程代码python_Python贪吃蛇游戏编写代码「建议收藏」

贪吃蛇编程代码python_Python贪吃蛇游戏编写代码「建议收藏」最近在学Python,想做点什么来练练手,命令行的贪吃蛇一般是C的练手项目,但是一时之间找不到别的,就先做个贪吃蛇来练练简单的语法。由于Python监听键盘很麻烦,没有C语言的kbhit(),所以这条贪吃蛇不会自己动,运行效果如下:要求:用#表示边框,用*表示食物,o表示蛇的身体,O表示蛇头,使用wsad来移动Python版本:3.6.1系统环境:Win10类:board:棋盘…

大家好,又见面了,我是你们的朋友全栈君。

贪吃蛇编程代码python_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.1

import 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很不一样

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

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/154052.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java锁cas(java锁的实现原理)

    一、Java锁1.常见的锁有synchronized和Lock()①synchronized是jvm层面实现的,可以直接用,不过要锁住某个对象;lock是属于j.u.c包下的接口,用的时候要实现lock接口。②synchronized一般和wait()、notify()、notifyAll()一起使用,使用完不用释放锁;lock必须在finally里面手动释放。@lock锁与s…

  • linux中top命令详解_top是什么命令

    linux中top命令详解_top是什么命令top命令Linuxtop命令用于实时显示process的动态。top参数详解第一行,任务队列信息**系统当前时间:**13:52:56**系统开机后到现在的总运行时间:**up66

  • Mysql实现同时交换两个表的表名

    Mysql实现同时交换两个表的表名转载自不服输的南瓜的Mysql实现同时交换两个表的表名表重命名有两种方式,所以交换两表名也有两种方式:方法一:locktablest1write,t2write;altertablet1renametot3;altertablet2renametot1;altertablet3renametot2;unlocktables;方法二:renametablet1tot3,t2tot1,t2tot3;…

  • pytest指定用例_pytest测试框架从入门到精通

    pytest指定用例_pytest测试框架从入门到精通前言测试用例在设计的时候,我们一般要求不要有先后顺序,用例是可以打乱了执行的,这样才能达到测试的效果.有些同学在写用例的时候,用例写了先后顺序,有先后顺序后,后面还会有新的问题(如:上个用例返回

  • 基于AWS云服务的批处理系统架构

    基于AWS云服务的批处理系统架构

  • springboot框架详解_springboot加载spring框架

    springboot框架详解_springboot加载spring框架一图胜千言:springboot容器启动流程:其中最重要的:运行机制为:springboot事件驱动:详情见:springboot事件驱动与观察者模式(http://www.cnblogs.com/dennyzhangdd/p/8343229.html)springboot启动流程图:分层图:…

发表回复

您的电子邮箱地址不会被公开。

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