更新:使用回溯法求解迷宫问题(获取最优路径)
原文章使用方法过于愚蠢,请忽略
说明 N 代表迷宫,A代表方位暂存器,V代表对应的N点是否被访问,AS代表方位存储器,Step代表下一步的操作。
1 |
|
原文章:
刚刚学完栈时,拿到这个题目的瞬间 感觉自己的栈知识都白学了。不是因为不会使用栈,而是因为自己一点解题思路都没有,后来通过自己的一些推敲和查看一些资料,终于弄明白了如何求解。
接下来通过写出一些关键点,大家可以加以参考)
解题思路
首先要建立一个用于存放方位信息的结构体类型Point(包括三个数据成员:行标row,列标col,下一步要走的方向way);
然后建立一个头节点指针类型LStack(包括方位信息Point类型的p 和 后继地址next),而这个链栈就是我们将要存放的路径信息。
分别写出入栈In和出栈Out的函数
遍历函数Display,注意因为栈的特性是先进后出,所有我们在显示的时候需要把链栈逆序输出
接下来就是最重要的Found,该函数要做的就是寻找路径
- 首先定义一个二维数组,这个数组map就是作为地图的存在,其中1代表不能走,0可走。
- 我们把数组的四边都定义为1,其余内部码入整个地图的数据;
- 定义Point类型的起点Home和End以及当前格子temp;
- 进入循环(当temp到达End时终止循环)当temp每到达新的一个格子时,都要对(除了temp原来的格子相对于当前temp的方向(比如原来temp在当前temp的上方,则在本次判定中不再对当前temp的上方进行判断))的所有方向进行判断:如果为0且路径链栈top的数据元素不含当前temp的值时则成功入栈,否则判断下一个方向。如果上下左右都不满足以上条件时则说明该格子是断头路需要退栈返回到上一个格子中并将该格子标记为-1。
- 如此循环下来,如果起点被标记成了断头路则说明该迷宫无正确路径,返回false。如果temp为终点End值则说明成功找到路径并以保存再链栈top中,返回true.
至此,我们的工作已经基本完成了,只需要再主函数main中建立一个链表再调用相关函数即可。
代码实现
1 |
|
目前存在的问题
在图中其实已经看的出来,在寻找路径时有可能会绕远路,虽然能够到达终点,但是这不符合我们寻找最优路径的期望