边玩边学!Python随机生成迷宫游戏的代码简单示例。

news2024/11/27 12:41:11

文章目录

  • 前言
  • 一、生成迷宫的二维数组
  • 二、深度优先搜索算法寻找通路
  • 三、生成迷宫的随机算法
  • 四、使用Pygame显示迷宫
  • 五、随机生成迷宫游戏完整代码
      • 关于Python技术储备
        • 一、Python所有方向的学习路线
        • 二、Python基础学习视频
        • 三、精品Python学习书籍
        • 四、Python工具包+项目源码合集
        • ①Python工具包
        • ②Python实战案例
        • ③Python小游戏源码
        • 五、面试资料
        • 六、Python兼职渠道


前言

随机生成迷宫游戏,是指使用随机算法生成一个可以解决的迷宫,玩家需要通过寻找通路,找到迷宫的出口。Python可以通过生成二维数组模拟迷宫的结构,使用深度优先搜索和广度优先搜索等算法找到通路。下面将从以下几个方面详细介绍。
在这里插入图片描述


一、生成迷宫的二维数组

迷宫是由一个二维数组来表示的,数组中每个元素表示迷宫的一个方块。使用Python可以通过numpy库来生成二维数组,例如二维数组shape为(5, 5)表示迷宫的大小为5x5,代码如下:

import numpy as np
# 生成迷宫的二维数组
maze = np.zeros((5, 5), dtype=int)  # 0 表示迷宫墙壁

以上代码中,使用zeros函数生成一个初始化为0的二维数组,因为0表示迷宫的墙壁。

二、深度优先搜索算法寻找通路

深度优先搜索算法可以用来寻找迷宫的通路。从一个起始点开始,每次选择一个未访问过的相邻方块,并标记为已访问。如果此时已经到达迷宫的终点,则返回找到的通路;如果当前方块没有未访问的相邻方块,则回溯到之前的方块,并选择另一个相邻方块。代码如下:

def dfs(maze, start, end):
    rows, cols = maze.shape
    visited = np.zeros((rows, cols))  # 标记迷宫中的方块是否已访问
    stack = [start]  # 栈存储待访问的方块
    directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # 定义四个方向
    while stack:
        current = stack.pop()
        if current == end:
            return True
        x, y = current
        visited[x][y] = 1
        for dx, dy in directions:
            new_x, new_y = x + dx, y + dy
            if 0 <= new_x < rows and 0 <= new_y < cols and not visited[new_x][new_y] and maze[new_x][new_y] == 1:
                stack.append((new_x, new_y))
    return False

三、生成迷宫的随机算法

随机算法主要用来生成迷宫的结构。使用深度优先搜索算法从起点到终点的过程中,同时将路径的方块标记为1,未标记的方块即为迷宫的墙壁。
在这里插入图片描述

def generate_maze(rows, cols, start, end):
    maze = np.zeros((rows, cols), dtype=int)  # 0表示墙
    stack = [start]  # 栈存储待访问的方块
    directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # 定义四个方向
    while stack:
        current = stack.pop()
        x, y = current
        maze[x][y] = 1  # 标记为访问过的方块
        neighbors = []
        for dx, dy in directions:
            new_x, new_y = x + dx, y + dy
            if 0 <= new_x < rows and 0 <= new_y < cols and maze[new_x][new_y] == 0:
                neighbors.append((new_x, new_y))
        if neighbors:
            stack.append(current)  # 当前方块重新压入栈
            next_block = neighbors[np.random.randint(len(neighbors))]  # 随机选择下一个方块
            if next_block == end:
                maze[next_block[0]][next_block[1]] = 1
                break
            stack.append(next_block)
    return maze

四、使用Pygame显示迷宫

使用Pygame库可以方便地显示迷宫的图像,代码如下:

import pygame
# 绘制迷宫
def draw_maze(screen, maze, size):
    rows, cols = maze.shape
    w, h = size[0] // cols, size[1] // rows
    for i in range(rows):
        for j in range(cols):
            if maze[i][j] == 0:
                pygame.draw.rect(screen, (0, 0, 0), (j * w, i * h, w, h))
            else:
                pygame.draw.rect(screen, (255, 255, 255), (j * w, i * h, w, h))
pygame.init()
# 窗口大小
size = (500, 500)
# 设置标题和窗口大小
pygame.display.set_caption("Maze Game")
screen = pygame.display.set_mode(size)
# 生成迷宫
maze = generate_maze(20, 20, (0, 0), (19, 19))
# 绘制迷宫
draw_maze(screen, maze, size)
pygame.display.flip()
running = True
while running:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            running = False
pygame.quit()

以上代码中,使用Pygame库生成一个500x500的窗口,并在窗口中绘制迷宫。Maze Game是窗口的标题,20x20表示迷宫的大小,(0,0)和(19,19)分别表示起点和终点。

五、随机生成迷宫游戏完整代码

以下是整个随机生成迷宫游戏的完整代码:

import pygame
import numpy as np
def dfs(maze, start, end):
    rows, cols = maze.shape
    visited = np.zeros((rows, cols))  # 标记迷宫中的方块是否已访问
    stack = [start]  # 栈存储待访问的方块
    directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # 定义四个方向
    while stack:
        current = stack.pop()
        if current == end:
            return True
        x, y = current
        visited[x][y] = 1
        for dx, dy in directions:
            new_x, new_y = x + dx, y + dy
            if 0 <= new_x < rows and 0 <= new_y < cols and not visited[new_x][new_y] and maze[new_x][new_y] == 1:
                stack.append((new_x, new_y))
    return False
def generate_maze(rows, cols, start, end):
    maze = np.zeros((rows, cols), dtype=int)  # 0表示墙
    stack = [start]  # 栈存储待访问的方块
    directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # 定义四个方向
    while stack:
        current = stack.pop()
        x, y = current
        maze[x][y] = 1  # 标记为访问过的方块
        neighbors = []
        for dx, dy in directions:
            new_x, new_y = x + dx, y + dy
            if 0 <= new_x < rows and 0 <= new_y < cols and maze[new_x][new_y] == 0:
                neighbors.append((new_x, new_y))
        if neighbors:
            stack.append(current)  # 当前方块重新压入栈
            next_block = neighbors[np.random.randint(len(neighbors))]  # 随机选择下一个方块
            if next_block == end:
                maze[next_block[0]][next_block[1]] = 1
                break
            stack.append(next_block)
    return maze
def draw_maze(screen, maze, size):
    rows, cols = maze.shape
    w, h = size[0] // cols, size[1] // rows
    for i in range(rows):
        for j in range(cols):
            if maze[i][j] == 0:
                pygame.draw.rect(screen, (0, 0, 0), (j * w, i * h, w, h))
            else:
                pygame.draw.rect(screen, (255, 255, 255), (j * w, i * h, w, h))
# 初始化Pygame库
pygame.init()
# 窗口大小
size = (500, 500)
# 设置标题和窗口大小
pygame.display.set_caption("Maze Game")
screen = pygame.display.set_mode(size)
# 生成迷宫的二维数组
maze = generate_maze(20, 20, (0, 0), (19, 19))
# 绘制迷宫
draw_maze(screen, maze, size)
# 刷新屏幕
pygame.display.flip()
# 事件循环
running = True
while running:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:  # 点击关闭按钮
            running = False
# 退出Pygame库
pygame.quit()

运行以上代码,即可生成随机生成迷宫游戏,并在Pygame窗口中显示。玩家需要自行找到通路,走到终点。


关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

👉CSDN大礼包:《Python入门资料&实战源码&安装工具】免费领取安全链接,放心点击

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、Python基础学习视频

② 路线对应学习视频

还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~在这里插入图片描述
在这里插入图片描述

③练习题

每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
在这里插入图片描述
因篇幅有限,仅展示部分资料

三、精品Python学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
在这里插入图片描述

四、Python工具包+项目源码合集
①Python工具包

学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
在这里插入图片描述

②Python实战案例

光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
在这里插入图片描述

③Python小游戏源码

如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
在这里插入图片描述

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述

六、Python兼职渠道

而且学会Python以后,还可以在各大兼职平台接单赚钱,各种兼职渠道+兼职注意事项+如何和客户沟通,我都整理成文档了。
在这里插入图片描述
在这里插入图片描述
这份完整版的Python全套学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1182331.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软考:中级软件设计师:2022年下半年上午软件设计师考题

软考&#xff1a;中级软件设计师:2022年下半年上午软件设计师考题 提示&#xff1a;系列被面试官问的问题&#xff0c;我自己当时不会&#xff0c;所以下来自己复盘一下&#xff0c;认真学习和总结&#xff0c;以应对未来更多的可能性 关于互联网大厂的笔试面试&#xff0c;都…

Scalable diffusion models with transformers

扩散模型之DiT&#xff1a;纯Transformer架构 - 知乎扩散模型大部分是采用 UNet架构来进行建模&#xff0c;UNet可以实现输出和输入一样维度&#xff0c;所以天然适合扩散模型。扩散模型使用的UNet除了包含基于残差的卷积模块&#xff0c;同时也往往采用self-attention。自从Vi…

OpenAI首席科学家:ChatGPT已经出现意识,人类未来将与AI融合

OpenAI首席科学家在最近的专访中抛出了很多惊人言论。在他看来&#xff0c;ChatGPT背后的神经网络已经产生了意识&#xff0c;而且未来人类会与人工智能融合起来&#xff0c;出现新的形态。而他现在工作的重点&#xff0c;已经不是去创建那个必然会出现的通用人工智能&#xff…

webgoat-Request Forgeries 请求伪造

(A8:2013) Request Forgeries Cross-Site Request Forgeries 跨站请求伪造&#xff0c;又称一键攻击或会话骑乘&#xff0c;简称CSRF &#xff08;有时发音为 sea-surf&#xff09;或 XSRF&#xff0c;是一种恶意利用网站&#xff0c;其中传输未经授权的命令 来自网站信任的用…

WebDAV之π-Disk派盘 + Keepass2Android

推荐一款密码管理器,允许人们使用复杂的组合进行登录,而不必记住所有的组合。 Keepass2Android可以支持大多数安卓互联网浏览器, Android设备上同步软件,还支持通过WebDAV添加葫芦儿派盘。 Keepass2Android 目前安全方面最大的问题之一是大多数人几乎在任何地方都使用通用…

第一百六十六回 如何创建以图片为背景的页面

文章目录 1. 概念介绍2. 实现方法2.1 整体思路2.2 具体步骤 3. 示例代码4. 内容总结 我们在上一章回中介绍了WheelChoose组件相关的内容&#xff0c;本章回中将介绍如何创建以图片为背景的页面&#xff0c;闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介绍 在实际…

SQL注入漏洞及五大手法

SQL注入漏洞 文章目录 SQL注入漏洞万能用户名 SQL注入分类两大基本类型五大手法提交参数方式注入点的位置 注入点判断SQL注入的危害sql漏洞挖掘Mysql库中的注释 SQL注入基本手法联合查询条件 报错注入group byextractvalueupdataxml 布尔盲注延时注入 案例获取cms网站后台管理员…

k8s 目录和文件挂载

k8s生产中常用的volumes挂载方式有&#xff1a;hostPath、pv&#xff0c;pvc、nfs 1.hostPath挂载 hostPath是将主机节点文件系统上的文件或目录挂载到Pod 中&#xff0c;同时pod中的目录或者文件也会实时存在宿主机上&#xff0c;如果pod删除&#xff0c;hostpath中的文…

字符函数和字符串函数详解

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 1. 字符分类函数 2. 字符转换函数 3. strlen的使用和模拟实现 3.1strlen的使用&#xff1a; 3.2strlen的模拟实现&#xff1a; 4. strcpy的使用和模拟实现 4.1strc…

YOLOv8-Cls推理详解及部署实现

目录 前言一、YOLOv8-Cls推理(Python)1. YOLOv8-Cls预测2. YOLOv8-Cls预处理3. YOLOv8-Cls推理 二、YOLOv8-Cls推理(C)1. ONNX导出2. YOLOv8-Cls预处理3. YOLOv8-Cls推理 三、YOLOv8-Cls部署1. 源码下载2. 环境配置2.1 配置CMakeLists.txt2.2 配置Makefile 3. ONNX导出4. 源码修…

网络安全深入学习第八课——代理与端口转发

文章目录 一、什么是代理二、正向代理三、反向代理四、正向和反向代理模拟复现 一、什么是代理 代理服务器英文全称是Proxy Server&#xff0c;其功能就是代理网络用户去取得网络信息。 形象的说&#xff1a;它是网络信息的中转站。在一般情况下&#xff0c;我们使用网络浏览…

​软考-高级-信息系统项目管理师教程 第四版【第20章-高级项目管理-思维导图】​

软考-高级-信息系统项目管理师教程 第四版【第20章-高级项目管理-思维导图】 课本里章节里所有蓝色字体的思维导图

解决 win11 vmware 中centos 网络不能访问外网

解决 win11 vmware 中centos 网络不能访问外网 1、进入win11 高级设置&#xff0c;找到centos 虚拟机使用的网卡 2、看网卡的其他属性 3、按照红圈部分&#xff0c;配置成一样的就行 4、进入到虚拟机配置中&#xff0c;配置成如图一样的NAT模式 5、再进入编辑 -》虚拟网络编辑…

30道高频Vue面试题快问快答

面试中的快问快答 快问快答的情景在面试中非常常见。 在面试过程中&#xff0c;面试官通常会使用快问快答的方式来快速评估面试者的基础知识、思维能力和反应速度。 这种情景下&#xff0c;面试官会提出一系列简短的问题&#xff0c;并期望面试者能够迅速做出回答或提供简洁明…

仿真实现lio_sam建图和ndt_matching定位

文章目录 一、仿真环境二、lio_sam建图1.修改配置文件2.开始建图 三、ndt_matching定位1.新建启动文件2.启动 总结 一、仿真环境 使用现有开源的仿真环境—从零开始搭建一台ROS开源迷你无人车&#xff0c;作者已经配置好小车模型以及gazebo环境&#xff0c;imu频率已改为200HZ…

Leetcode—2586.统计范围内的元音字符串数【简单】

2023每日刷题&#xff08;二十二&#xff09; Leetcode—2586.统计范围内的元音字符串数 实现代码 class Solution { public:int vowelStrings(vector<string>& words, int left, int right) {int ans 0;for(int i left; i < right; i) {string s words[i];i…

原子化 CSS 真能减少体积么?

前言 最近看到这样一篇文章&#xff1a;《要喷也得先做做功课吧&#xff1f;驳Tailwind不好论》 个人觉得说的还是有一定道理的&#xff0c;就是该作者的语气态度可能稍微冲了点&#xff1a; 不过他说的确实有道理&#xff0c;如果这种原子化工具真的如评论区里那帮人说的那么…

苹果手机的警示!电子产品无线升级=救命的机会

大家日常使用手机都知道&#xff0c;手机系统和软件三天两头就收到更新提醒。 只要用户手机联网&#xff0c;就可以想更新就更新&#xff0c;觉得原本使用顺手也可以不更新。 可各大厂商的初衷是好的&#xff0c;希望改善系统的一些bug问题&#xff0c;也会给我们带来一些全新功…

强化学习中的基本术语

0.引言 本篇文章主要介绍强化学习中最基本的术语&#xff08;不包含具体算法&#xff09;&#xff0c;主要提供给刚入门强化学习的朋友们&#xff0c;让大家快速掌握一些基本术语&#xff0c;之后对看强化学习算法内容有着更好地理解。 1.基本术语 1.1.state 中文称为“状态…

基于ssm企业人事管理系统

功能如图所示 摘要 基于SSM&#xff08;Spring SpringMVC MyBatis&#xff09;框架的企业人事管理系统是一种高效、可定制化的人力资源管理解决方案。该系统整合了现代企业的人力资源需求&#xff0c;提供了一套功能丰富的工具&#xff0c;用于管理员工信息、薪资、考勤、招聘…