栈和队列综合实验报告.doc

栈和队列综合实验报告.doc

ID:56773859

大小:42.50 KB

页数:3页

时间:2020-07-08

栈和队列综合实验报告.doc_第1页
栈和队列综合实验报告.doc_第2页
栈和队列综合实验报告.doc_第3页
资源描述:

《栈和队列综合实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、栈和队列综合实验报告一、实验目的(1)能够利用栈和队列的基本运算进行相关操作。(2)进一步熟悉文件的应用(3)加深队列和栈的数据结构理解,逐步培养解决实际问题的编程能力。二、实验环境装有VisualC++6.0的计算机。本次实验共计4学时。三、实验内容以下两个实验任选一个。1、迷宫求解设计一个迷宫求解程序,要求如下:ü以M×N表示长方阵表示迷宫,求出一条从入口到出口的通路,或得出没有通路的结论。ü能任意设定的迷宫ü(选作)如果有通路,列出所有通路提示:ü以一个二维数组来表示迷宫,0和1分别表示迷宫中的通路和障碍,如下图迷宫数据为:111

2、1111111100100010110010001011000011001101110000110001000011010001001101110110111000000011111111111入口位置:11出口位置:88四、重要数据结构typedefstruct{intj[100];inttop;栈顶指针,一直指向栈顶}stack;//存放路径的栈ints[4][2]={{0,0},{0,0},{0,0},{0,0}};//用于存放最近的四步路径坐标的数组,是即使改变的,即走一步,便将之前的坐标向前移一步,将最早的一步坐标覆盖掉,新的

3、一步放入数组末尾其实功能和队列一样。其作用是用来判断是否产生了由于本程序算法产生的“田”字方格内的死循环而准备的,用于帮助跳出循环。五、实现思路分析if(a[m][n+1]==0&&k!=3){n++;k=1;o=0;}elseif(a[m+1][n]==0&&k!=4){m++;k=2;o=0;}elseif(a[m][n-1]==0&&k!=1){n--;k=3;o=0;}elseif(a[m-1][n]==0&&k!=2){m--;k=4;o=0;}else{o++;}if(o>=2){k=0;}//向所在方格的四个方向探路,探路

4、顺序为→↓←↑(顺时针),其中if判断条件内的&&k!=n和每个语句块中的对k赋值是为防止其走回头路进入死循环,而最后一个else{}内语句是为了防止进入死路时,不能走回头路而造成的死循环。push(q,m,n);//没进行一次循环都会讲前进的路径入栈。if(pushf(&s[0][0],m,n)==0){k=3;}//用来判断是否产生了由于本程序探路算法产生的“田”字方格内的死循环而准备的,用于帮助跳出田字循环。同时会将路径存入用于下次判断六、程序调试问题分析最开始写完时是没有死路回头机制的,然后添加了两步内寻路不回头机制。第二个是“

5、田”字循环问题,解决方法是加入了一个记录最近四步用的数组和一个判断田字循环的函数pushf。intpushf(int*a,intm,intn){intj=0;if(m==a[0]&&n==a[1]){//判断最新的一步是否和4步之前的走的是同一个坐标点,//从而返回判断值,以便跳出循环。return0;}while(j<8){//如果没有发生田字训话,将4*2数组内的4组坐标向前移动覆盖掉最//早的一步,放入最新的一步。a[j]=a[j+2];a[j+1]=a[j+3];j=j+2;}a[6]=m,a[7]=n;return1;}另外由

6、于探路算法特新并不会产生3x3,4x4等的方阵循环。想到的隐藏问题:如果是3x3方阵,但中间的一块是墙的话就会产生3x3方阵的死循环。七、实验总结熟悉了栈的应用和操作。对问题的考虑不够彻底,且写程序前所能想到的问题少。程序整规划能力欠缺,照成可读性不高。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。