深度优先遍历之迷宫生成算法

2024-09-01 23:38

本文主要是介绍深度优先遍历之迷宫生成算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、图的深度优先遍历简介  

 

例如,要遍历上面这个图 
采取深度优先算法(从1开始) 
准备一个Stack s,预定义三种状态:A未被访问 B正准备访问 C已经访问 
一、访问1,把它标记为已经访问,然后将于它相邻的并且标记为未被访问的点压入s 中并标记为正准备访问 
此时系统状态: 
已经被访问的点:1 
还没有被访问的点:3 4 6 7 8 9 10 
正准备访问的点:2 5 (存放在Stack之中) 

二、从Stack中拿出第一个元素 2,标记为已经访问,然后将于它相邻的并且标记为未被访问的点压入s 中并标记为正准备访问,如图: 

 

此时系统状态: 
已经被访问的点:1 2 
还没有被访问的点: 4 6 7 8 9 10 
正准备访问的点:3 5 (存放在Stack之中) 

三、从Stack中拿出第一个元素 3,标记为已经访问,然后将于它相邻的并且标记为未被访问的点压入s 中并标记为正准备访问,如图: 

 

此时系统状态: 
已经被访问的点:1 2 3 4 
还没有被访问的点:8 9 10 
正准备访问的点:7 6 5 (存放在Stack之中) 
依此类推,重复上面的动作,直到Stack为空,即所有的点都被访问。 

  最后可能的遍历情况,如图: 

 

2、深度优先遍历之迷宫生成算法  

  那么,这样该如何生成迷宫呢? 

  不知大家注意到了没有,这种算法每一个步骤都要执行一个操作,把刚刚访问过的点的相邻的并且没有标记为被访问过的点压入Stack s中,然后下一步访问的就是Stack中的第一个元素。那么,当一个点有多个相邻点的话,该按什么顺序压入呢?随机。这就是随机生成迷宫的核心所在! 

  现在我们换个角度看待问题。 

  例如需要生成一个5 * 5的迷宫。坐标为(1,1) (3,1) (1,3) (3,3)的①、②、③、④分别代表节点,它们肯定可让人通过,然后,如果(2,1)设置成可通过,就代表①?②可通过,结合图的遍历算法,我们看到,当我们从①访问到②时,就把(2,1)设置为可通过,就相当开辟了一条道路,等到遍历结束,迷宫就生成了。

 

  上图中的①②③④,我们可看为一个2 * 2的矩阵,如图: 

 

  关键是在什么时候“开辟这条道路”。以上节中图的深度优先遍历简介为例子。假设依次访问到的点是:1 2 3 4 7 10 9 8 6 5 
当刚刚访问到 9 时,会把8 6 压入Stack中,所以应该开通 9 到 8和6的道路,这样就可自动生成迷宫了。 

3、迷宫路径的唯一性  

  这个算法,大家应该很清楚地看到,从起点到终点的路是唯一的(可以任选两点作为起点和终点) 

4、算法的缺点  

  算法只能生成一个m * n的迷宫,其中m、n都是奇数。


这篇关于深度优先遍历之迷宫生成算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128377

相关文章

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1