迷宫最短路求解

该博客探讨了如何使用非递归方法解决迷宫问题,重点在于找到走出迷宫的最短路径。通过使用结构体数据类型来存储路径信息,并结合C++的FIFO队列实现BFS算法,博主成功地实现了这一目标。此外,还讨论了如何进行记忆化搜索以打印路径。文章包含了算法的时间复杂度分析和可能的改进方案。
摘要由CSDN通过智能技术生成

任务: 可以输入一个任意大小的迷宫数据,用非递归的方法求出一条走出迷宫的路径,并将路径输出。
要求:写明存储结构、迷宫求解的算法(可以使用程序流程图)、源程序、测试数据和结果、算法的时间复杂度、另外可以提出算法的改进方法。

思路: 此题要求一个走出迷宫的路径,我这里还实现了求迷宫的最短路,最短路问题我用两个工具来实现,一是使用结构体数据类型,因为每一步都包含x轴,y轴,步数和其他一些参数,这样的话就使结构更加清晰,二是我使用了C++标准模板库的先进先出队列,通过对bfs经典算法的实现,这使我轻而易举的实现了求最短路。因为题目还涉及到一个打印路径的问题,所以我们还要加上记忆化搜索。

代码:

#include"stdio.h"
#include"string.h"
#include"queue"
using namespace std;

const int maxn=100;
char ai[maxn][maxn];
int x1,y1,x2,y2,m,n;
bool used[maxn][maxn];
int fx[4][2]={
  1,0,-
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值