南京工业大学 数据结构 实验报告3.docx
- 文档编号:2883204
- 上传时间:2022-11-16
- 格式:DOCX
- 页数:17
- 大小:73.94KB
南京工业大学 数据结构 实验报告3.docx
《南京工业大学 数据结构 实验报告3.docx》由会员分享,可在线阅读,更多相关《南京工业大学 数据结构 实验报告3.docx(17页珍藏版)》请在冰豆网上搜索。
南京工业大学数据结构实验报告3
《数据结构》实验报告三
题目:
迷宫问题
班级:
电子1102
学号:
28
姓名:
杨筠
日期:
6月1日
程序名:
一、上机实验的问题和要求:
迷宫问题(书P503.2.4和《数据结构题集》P1052.9):
以一个m×n的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍。
设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论。
利用链栈结构,然后编写一个求解迷宫的非递归程序。
求得的通路以三元组(i,j,d)的形式输出,其中:
(i,j)指示迷宫中的一个坐标,d表示走到下一坐标的方向。
如:
对于下列数据的迷宫,输出的一条通路为:
(1,1,1),(1,2,2),(2,2,2),(3,2,3),….。
测试数据:
0
0
1
0
0
0
1
0
0
0
1
0
0
0
1
0
0
0
0
0
1
1
0
1
0
1
1
1
0
0
1
0
0
0
0
1
0
0
0
0
0
1
0
0
0
1
0
1
0
1
1
1
1
0
0
1
1
1
0
0
0
1
0
1
1
1
0
0
0
0
0
0
★鼓励图形化的输入输出界面设计
★设计递归算法,求出迷宫中所有可能的通路
二、程序设计的基本思想,原理和算法描述:
(包括程序的结构,数据结构,输入/输出设计,符号名说明等)
迷宫求解问题主要运用了堆栈的性质
求迷宫中一条从入口到出口的路径的算法描述:
do
{
若当前位置可通
则{
将当前位置插入栈顶;
若该位置时出口位置,则结束;
否则切换当前位置为东邻方块为新的当前位置;
}
否则
{
若栈不空且栈顶位置尚有其他方向未经探索,
则设定新的当前位置为沿顺时针方向旋转的栈顶位置的下一相邻模块
若栈不空但栈顶位置的四周均不可通
则{
删去栈顶位置;
若栈不空,则重新测试新的栈顶位置
直至找到一个可通的相邻模块或出栈至栈空;
}
}
}while(栈不空)
实现的函数为
/**************************************************************
若迷宫maze中从入口start到出口end的通道,则求得一条存放在栈中
**************************************************************/
StatusMazePath(intmaze[12][12],SqStack&S,PosTypestart,PosTypeend)
{
PosTypecurpos;
intcurstep;
SElemTypee;
InitStack(S);
curpos=start;//设定"当前位置"为"入口位置
curstep=1;//探索第一步
do
{
if(Pass(maze,curpos))//当前位置可通过,即是未曾走到过的通道块
{
Markfoot(maze,curpos);//留下足迹
e.di=1;
e.ord=curstep;
e.seat=curpos;
Push(S,e);//加入路径
if(curpos.row==end.row&&curpos.line==end.line)
returnOK;//到达终点(出口)
curpos=NextPos(curpos,1);//下一位置是当前位置的东邻
curstep++;//探索下一步
}
else//当前位置不能通过
{
if(!
StackEmpty(S))
{
Pop(S,e);
while(e.di==4&&!
StackEmpty(S))
{
Markfoot(maze,e.seat);//留下不能通过的标记,并退回一步
Pop(S,e);
}
if(e.di<4)
{
e.di++;//换下一个方向探索
Push(S,e);
curpos=NextPos(e.seat,e.di);//当前位置设为新方向的//相邻块
}
}
}
}while(!
StackEmpty(S));
returnERROR;
}
围绕这个函数需要定义一些相关的函数操作,由以下函数实现
/**************************************************************
函数原型说明
**************************************************************/
StatusInitStack(SqStack&S);//创建一个空栈S
StatusPush(SqStack&S,SElemType&a);//插入新元素a
StatusPop(SqStack&S,SElemType&a);//删除栈顶元素,a返回其值
StatusStackEmpty(SqStackS);//检查是否空栈
StatusMazePath(intmaze[12][12],SqStack&S,PosTypestart,PosTypeend);//找通路
voidInitmaze(intmaze[12][12],intsize);//初始化迷宫
voidprintmaze(intmaze[12][12],intsize);//显示迷宫
StatusPass(intmaze[12][12],PosTypeCurPos);//判断当前位置是否可通
voidMarkfoot(intmaze[12][12],PosTypeCurPos);//标记当前位置不可通
PosTypeNextPos(PosTypeCurPos,intDir);//进入下一位置
voidprintpath(intmaze[12][12],SqStackS,intsize);//显示通路
算法中我用正方形迷宫,即行数等于列数。
迷宫的存储我用了一个整形二维数组表示,
intsize;//正方形迷宫尺寸
intmaze[12][12];//存储迷宫内路径可通情况
二维数组存储的数字表示对应迷宫位置处可通与否,0表示可通,1表示不可通。
尺寸大小size可以设置,但是不能超过10,因为二维数组第一行,最后一行,第一列,最后一列一定要是不可通的,这是算法中用到的一个技巧。
迷宫内通道块位置变量类型定义为PosType
typedefstruct
{
introw;//row表示“行”号
intline;//line表示“列”号
}PosType;//位置的元素类型
这样判断其可通与否的语句为
if(maze[CurPos.row][CurPos.line]==0)
1.迷宫的初始化
voidInitmaze(intmaze[12][12],intsize);//初始化迷宫
迷宫的初始化有两种方法,一是随即生成,一是手动设置,由用户选择。
随即生成的方法是程序生成随机数,除以2取余
maze[i][j]=rand()%2;
手动设置是用户输入0,1由程序读取
scanf("%d",&maze[i][j]);
2.显示迷宫
voidprintmaze(intmaze[12][12],intsize);//显示迷宫
只需要整齐打印出0,1即可,可以看到很好的效果
显示初始化的迷宫。
3.显示通路
voidprintpath(intmaze[12][12],SqStackS,intsize);//显示通路
用到了一个技巧,只要是纳入堆栈的位置元素即为通路上的路径,将其迷宫对应位置
值变为2,
while(p!
=S.top)
{
maze[p->seat.row][p->seat.line]=2;//标记为路径中的点
p++;
}
然后显示通路时只要等于2的地方就打印一个0,否则打印空格。
if(maze[i][j]==2)printf("%c",'0');
elseprintf("");
程序见第三部分。
4.进入下一位置
PosTypeNextPos(PosTypeCurPos,intDir);//进入下一位置时按顺时针方向
//向下一位置探索
5.堆栈操作,包括创建,入栈,出栈,判空。
StatusInitStack(SqStack&S);//创建一个空栈S
StatusPush(SqStack&S,SElemType&a);//插入新元素a
StatusPop(SqStack&S,SElemType&a);//删除栈顶元素,a返回其值
StatusStackEmpty(SqStackS);//检查是否空栈
程序见第三部分。
三、源程序及注释:
#include
/**************************************************************
数据定义
**************************************************************/
typedefenum{ERROR,OK}Status;
typedefstruct
{
introw;//row表示“行”号
intline;//line表示“列”号
}PosType;//位置的元素类型
typedefstruct
{
intord;//该通道在路径上的“序号”
PosTypeseat;//通道块在迷宫中的“坐标位置”
intdi;//从此通道走向下以通道块的“方向”
}SElemType;//栈的元素类型
typedefstruct
{
SElemType*base;
SElemType*top;
intstacksize;
}SqStack;
/**************************************************************
函数原型说明
**************************************************************/
StatusInitStack(SqStack&S);//创建一个空栈S
StatusPush(SqStack&S,SElemType&a);//插入新元素a
StatusPop(SqStack&S,SElemType&a);//删除栈顶元素,a返回其值
StatusStackEmpty(SqStackS);//检查是否空栈
StatusMazePath(intmaze[12][12],SqStack&S,PosTypestart,PosTypeend);//找通路
voidInitmaze(intmaze[12][12],in
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 南京工业大学 数据结构 实验报告3 南京 工业大学 实验 报告