堆栈遍历求解迷宫(程序说明书).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构》 课程设计姓名 虞嘉尧班级 信科1301学号 程序名:迷宫求解 实验环境:Visual c++ 6.0 语言c++ 实现功能:随机生成一个迷宫并判断此迷宫是否走得通 主要算法:从入口出发,以右、下、上、左方向顺序试探下一坐标是否走得通,同时将可走方位保存,再进行下一步试探,用堆栈方式实现迷宫遍历。运行界面:实例:主要源代码: #include iostream #include windows.h #include time.h #include stack using namespace std; typedef struct seat//坐标 {int x;int y;int di; }Seat;typedef struct _stack//节点 {Seat seat;struct _stack *next; }MyStack, Head; int m,n; int maze[30][30]; int InMaze();//初始化迷宫 int PrintMaze();//打印迷宫void Dis(stackSeat );//走完后路径打印 void GetNext(Seat , Seat );//获取下一个坐标 void InData(Seat , Seat , Seat , Seat );//初始化位置 int NextPas(Seat , Seat , stackSeat );//判定下一个坐标是否通过int main() {int flag = 0; stackSeat road;Seat start, end, next, cur;while(1){InMaze();InData(start, end, cur, next);system(cls);PrintMaze();flag = 0;while(!road.empty())road.pop();while(1){while(cur.di = 4){++cur.di;maze[cur.x][cur.y] = 2;if(cur.x == end.x cur.y == end.y){cur.di = 8;road.push(cur);cout\n\n成功走出!\n\n路径:\n;stackSeat temp;Seat a;while(!road.empty()){a = road.top();road.pop();temp.push(a);}Dis(temp);flag = 1;break;}GetNext(cur, next);if(NextPas(cur, next, road)){cur = next;Sleep(500);system(cls);PrintMaze();}}if(flag == 1)break;maze[cur.x][cur.y] = 7;if(road.empty()){cout\n\n无法走出\n\n;flag = 1;break;}if(flag == 1)break;cur = road.top();road.pop();}system(pause);}return 0; }int InMaze()//初始化迷宫 {coutThe size of maze:endl; cinmn; int x, i, j;srand (time(NULL));for(i = 0; i m; ++i) {for(j = 0; j n; ++j){x = rand() % 2 + 1;if(i == 0 || j == 0 || i == m-1 || j == n-1)maze[i][j] = 1;else if(x == 2)maze[i][j] = 0;else if(x == 1)maze[i][j] = 1;}}maze[1][1] = 0;maze[m-2][n-2] = 0;return 1; }int PrintMaze()//打印迷宫 {for(int i = 0; i m; ++i){for(int j = 0; j n; ++j){if(i == 1 j == 1)cout▲;else if(i == m-2 j == n-2)cout★;else if(maze[i][j] == 0)cout ;else if(maze[i][j] == 1)cout■;else if(maze[i][j] == 2)cout→;else if(maze[i][j] == 3)cout→;else if(maze[i][j] == 4)cout↓;else if(maze[i][j] == 5)cout↑;else if(maze[i]

文档评论(0)

yanpan1 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档