




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、2、用栈求解用栈求解迷宫问题迷宫问题 给定一个给定一个MN的的迷宫图迷宫图、入口与出口入口与出口、行走规则行走规则。求。求一条从指定入口到出口的路径。一条从指定入口到出口的路径。 所求路径必须是所求路径必须是简单简单路径路径,即,即路径不重复。路径不重复。1/20 行走规则行走规则:上、下、左、右相邻方块行走。其中:上、下、左、右相邻方块行走。其中(i,j)表示一个方块)表示一个方块方位方位0方位方位2方位方位1方位方位3i,ji-1,ji,j+1i,j-1i+1,j2/200 1 2 3 4 5 6 7 8 90 1 2 3 4 5 6 7 8 9入入口口出出口口 例如,例如,M=8,N=8
2、,图,图中的中的每个每个方块,用方块,用空白空白表示表示通道,通道,用用阴影表示障碍物。为了阴影表示障碍物。为了算法算法方便,一般方便,一般在迷宫外围加上了在迷宫外围加上了一条围墙。一条围墙。一条迷宫路径一条迷宫路径3/20 设置一个迷宫设置一个迷宫数组数组mg,其中,其中每个元素表示一个方块每个元素表示一个方块的的状态,为状态,为0时表示对应方块时表示对应方块是是通道,为通道,为1时表示对应方块不时表示对应方块不可走。可走。4/20int mgM+2N+2= 1, 1,1,1,1,1,1,1,1, 1, 1, 0,0,1,0,0,0,1,0, 1, 1, 0,0,1,0,0,0,1,0, 1
3、, 1, 0,0,0,0,1,1,0,0, 1, 1, 0,1,1,1,0,0,0,0, 1, 1, 0,0,0,1,0,0,0,0, 1, 1, 0,1,0,0,0,1,0,0, 1, 1, 0,1,1,1,0,1,1,0, 1, 1, 1,0,0,0,0,0,0,0, 1, 1, 1,1,1,1,1,1,1,1, 1;0 1 2 3 4 5 6 7 8 90 1 2 3 4 5 6 7 8 9MN5/20在算法中用到的栈采用顺序栈在算法中用到的栈采用顺序栈存储存储结构,即将结构,即将栈定义为:栈定义为:typedef struct int i;/当前方块的行号当前方块的行号 int j;/
4、当前方块的列号当前方块的列号 int di;/di是下一可走相邻方位的方位号是下一可走相邻方位的方位号 Box;/定义方块类型定义方块类型typedef struct Box dataMaxSize; int top;/栈顶指针栈顶指针 StType;/定义顺序栈类型定义顺序栈类型i,jx,ydi6/20试探顺序:试探顺序:从方位从方位0开始,顺时针开始,顺时针方向方向方位方位0方位方位2方位方位1方位方位3i,ji- -1,ji,j+1i,j- -1i+1,j7/20i,jijdiij- -1栈栈将将(i,j,- -1)进栈)进栈初始初始时,入口时,入口(i,j)作为当前方块。)作为当前方块
5、。所有走过的方块都会进栈!所有走过的方块都会进栈!8/20 如果一个当前方块如果一个当前方块(i,j)找到一个相邻可走方块)找到一个相邻可走方块(x,y),),就就继续从继续从(x,y)走下去。)走下去。i,jx,y方位方位dijdiijd栈栈将将(x,y,- -1)进栈)进栈xy- -19/20 如果一个当前方块如果一个当前方块(i,j)没有找到任何相邻可)没有找到任何相邻可走走方块,表方块,表示示此时此时无路无路可可走走,将,将其退栈。其退栈。i,jijdiijd栈栈将将(i,j,d)退栈)退栈10/20求解迷宫路径的求解迷宫路径的过程:过程:前一方块前一方块当前方块当前方块回溯回溯找其他
6、可能的相邻方块找其他可能的相邻方块所有相邻方块都不能走所有相邻方块都不能走11/20bool mgpath(int xi,int yi,int xe,int ye)/求解路径为求解路径为:(xi,yi)-(xe,ye) Box pathMaxSize, e; int i,j,di,i1,j1,k; bool find; StType *st;/定义栈定义栈st InitStack(st);/初始化栈顶指针初始化栈顶指针 e.i=xi; e.j=yi; e.di=-1;/设置设置e为入口为入口 Push(st,e);/方块方块e进栈进栈 mgxiyi=-1;/入口的迷宫值置为入口的迷宫值置为-1
7、避免重复走到该方块避免重复走到该方块用栈求一条迷宫路径的用栈求一条迷宫路径的算法算法: (xi,yi) (xe,ye) 0 1 2 3 4 50 1 2 3 4 5i j di11- -1一个栈一个栈为了为了避免避免重复,当重复,当一个方块进一个方块进栈栈时,时,将将迷宫值改为迷宫值改为- -112/20while (!StackEmpty(st)/栈不空时循环栈不空时循环 GetTop(st,e);/取栈顶方块取栈顶方块e i=e.i; j=e.j; di=e.di; if (i=xe & j=ye)/找到了找到了出口出口,输出输出该路径该路径 printf(一条迷宫路径如下一条迷宫
8、路径如下:n); k=0;while (!StackEmpty(st) Pop(st,e);/出栈方块出栈方块e pathk+=e;/将将e添加到添加到path数组中数组中13/20 while (k=1) k-; printf(t(%d,%d),pathk.i,pathk.j); if (k+2)%5=0) /每输出每每输出每5个方块后换一行个方块后换一行 printf(n); printf(n); DestroyStack(st);/销毁栈销毁栈 return true;/输出一条迷宫路径后返回输出一条迷宫路径后返回true i j di11- -1 112- -113- -124- -1
9、23- -1121233- -1 143- -1 144- -1 14/20 find=false; while (didatast-top.di=di; /修改原栈顶元素的修改原栈顶元素的di值值 e.i=i1; e.j=j1; e.di=-1; Push(st,e); /相邻可走方块相邻可走方块e进栈进栈 mgi1j1=-1;/(i1,j1)迷宫值置为迷宫值置为-1避免重复走到该方块避免重复走到该方块 从入口从入口(1,1)出发找到一个可走方)出发找到一个可走方块块(1,2):将将(1,2,-1)进栈)进栈i j di111一个栈一个栈12-116/20 else/没有路径可没有路径可走走,则则退栈退栈 Pop(st,e);/将栈顶方块退栈将栈顶方块退栈mge.ie.j=0; /让退栈方块的位置变为其他路径可走方块让退栈方块的位置变为其他路径可走方块 DestroyStack(st);/销毁栈销毁栈 return false;/表示没有可走路径表示没有可走路径(2,4)方块没有通路)方块没有通路i j di一个栈一个栈24-1 退退栈栈疑难解答:这里不将mg栈顶方块设置为0,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 环保产业协同发展合作条款合同
- 大型体育场馆建设施工合同
- 智能城市合作框架及实施细节合同
- 国际海上物流保险合同样本
- 企业返聘退休人员合同模板
- 合同执行过程中的安全施工标准范本2025
- 劳动合同解除与补偿案例范文
- 合同法修订前瞻:劳动者权益保护再升级
- 带见证人离婚合同模板
- 战略合作投资合同保密协议模板
- 2025年牡丹江大学单招职业适应性测试题库及答案(典优)
- 2025年河南工业职业技术学院单招职业技能测试题库审定版
- 包材检验流程
- 2024年湖南司法警官职业学院高职单招职业技能测验历年参考题库(频考版)含答案解析
- 2025年四川成都职业技术学院招聘笔试参考题库含答案解析
- 商业楼宇电气设施维修方案
- 乳腺疾病的筛查与预防
- 《丝巾无限可能》课件
- 家庭教育与孩子的阅读习惯培养
- 2024年10月自考00058市场营销学真题和答案
- 部队安全保密教育课件
评论
0/150
提交评论