C++ 迷宫寻路问题
迷宫寻路应该是栈结构的一个非常经典的应用了, 最近看数据结构算法应用时看到了这个问题, 想起来在校求学时参加算法竞赛有遇到过相关问题, 感觉十分亲切, 在此求解并分享过程, 如有疏漏, 欢迎指正
问题描述: 非常简洁明了的问题, 即对于一个由1,0构成的矩阵, 找到一条用0连接起来的从(1,1)到(10,10)的路径
思路: 用栈结构存储路径, 每经过一个点, 将点坐标存入栈, 并在矩阵中将此坐标点值置1, 循环直至找到点(10,10), 若中途没找到可以继续前进的点且栈为空, 则说明当前迷宫无解
代码如下:
#include <iostream>
#include <stack> //坐标
typedef struct _struct_pos
{
_struct_pos()
{
x = ;
y = ;
} int x;
int y;
}Pos; //地图
int g_maze_arr[][] = {{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,},
{,,,,,,,,,,,}}; //路径栈
std::stack<Pos> g_stack_path; /***************************************************************
*
*/
void print_pos(const Pos &pos)
{
std::cout << "[" << pos.x
<< "," << pos.y
<< "]" << std::endl;
} //检查出口
bool find_next(const Pos &curr_pos, Pos &next_pos)
{
//当前坐标
int x = curr_pos.x;
int y = curr_pos.y; //生成四个方向的坐标
Pos top, down, left, right;
top.x = x;
top.y = y - ;
down.x = x;
down.y = y + ;
left.x = x - ;
left.y = y;
right.x = x + ;
right.y = y; //判断四个方向有无通路
if (g_maze_arr[top.x][top.y] == )
{
next_pos.x = top.x;
next_pos.y = top.y;
std::cout << "find way : ";
print_pos(next_pos);
return true;
}
else if (g_maze_arr[down.x][down.y] == )
{
next_pos.x = down.x;
next_pos.y = down.y;
std::cout << "find way : ";
print_pos(next_pos);
return true;
}
else if (g_maze_arr[left.x][left.y] == )
{
next_pos.x = left.x;
next_pos.y = left.y;
std::cout << "find way : ";
print_pos(next_pos);
return true;
}
else if (g_maze_arr[right.x][right.y] == )
{
next_pos.x = right.x;
next_pos.y = right.y;
std::cout << "find way : ";
print_pos(next_pos);
return true;
}
else
{
std::cout << "no way find in :";
print_pos(curr_pos);
return false;
}
} //寻找路径
bool find_path()
{
Pos st_curr_pos, st_next_pos; //起点
st_curr_pos.x = ;
st_curr_pos.y = ;
g_maze_arr[][] = ; //不为终点坐标,继续查找路径
while ((st_curr_pos.x != ) || (st_curr_pos.y != ))
{
//找到下一路径
if (find_next(st_curr_pos, st_next_pos))
{
//记录下一个位置并置标记为1
g_stack_path.push(st_next_pos);
st_curr_pos = st_next_pos;
g_maze_arr[st_next_pos.x][st_next_pos.y] = ;
}
//无路可走
else
{
//路径栈为空,且无路可退,此迷宫无解
if (g_stack_path.empty())
{
return false;
}
//根据栈内信息,回退一步
else
{
st_curr_pos = g_stack_path.top();
g_stack_path.pop();
}
}
} return true;
} //输出路径
void print_path()
{
while (!g_stack_path.empty())
{
Pos st_curr_pos = g_stack_path.top(); std::cout << "[" << st_curr_pos.x
<< "," << st_curr_pos.y
<< "]" << std::endl; g_stack_path.pop();
}
}
测试如下:

结果

C++ 迷宫寻路问题的更多相关文章
- PTA7-1 迷宫寻路 (20分)
7-1 迷宫寻路 (20分) 给定一个M行N列的迷宫图,其中 "0"表示可通路,"1"表示障碍物,无法通行.在迷宫中只允许在水平或上下四个方向的通路上行走,走过 ...
- NEFU 558 迷宫寻路
题目链接 简单搜索题 #include <cstdio> #include <iostream> #include <cstring> using namespac ...
- HTML 迷宫
今天补个遗,将很久以前研究 HTML5 的时候写的生成迷宫.迷宫寻路程序整理出来. 下载链接在文章最后. 简介 为什么要做这个 HTML5 迷宫程序?因为我喜欢.我愿意.也是向老程序员学习(见第5节) ...
- AI-随机迷宫&迷宫求解
本文记录了,人工智能中简单的搜索策略中的路径搜索策略中的A*算法,来实现迷宫寻路的问题.(这只是一次本人的课外作业) 完整的程序源码已经发送到我的Git.这里只记录了我的思路和感想以及收获. 产生随机 ...
- 【转】A*寻路算法 C++实现
头文件:AStarPathFinding #ifndef ASTARPATHFINDING_H #define ASTARPATHFINDING_H #include <queue>//为 ...
- PTA-迷宫寻路(输出最短路径)
给定一个M行N列的迷宫图,其中 "0"表示可通路,"1"表示障碍物,无法通行.在迷宫中只允许在水平或上下四个方向的通路上行走,走过的位置不能重复走. 5行8列的 ...
- 用Java语言编写的迷宫小游戏软件
可查看本项目的github 源码链接,撒娇打滚求 star 哦~~ღ( ´・ᴗ・ ` )比心 本仓库代码是经过 eclipse 编译运行过的,一般情况下将本仓库代码下载下来之后,使用 eclipse ...
- 【小白学游戏常用算法】二、A*启发式搜索算法
在上一篇博客中,我们一起学习了随机迷宫算法,在本篇博客中,我们将一起了解一下寻路算法中常用的A*算法. 通常情况下,迷宫寻路算法可以使用深度优先或者广度优先算法,但是由于效率的原因,不会直接使用这些算 ...
- canvas——路径搜索
在前一篇博客中随机生成迷宫,现在就以随机生成的迷宫为地图,开始寻找路径. 迷宫寻路也可以使用DFS,BFS,但常见的是A*算法,它是启发式搜索算法的一种,效率相比前两者也更高.接下来以A*算法为例,迷 ...
随机推荐
- [徐州网络赛]Longest subsequence
[徐州网络赛]Longest subsequence 可以分成两个部分,前面相同,然后下一个字符比对应位置上的大. 枚举这个位置 用序列自动机进行s字符串的下标转移 注意最后一个字符 #include ...
- Mysql_常规操作
001.数据库 全局操作 # 连接数据库: # mysql -h主机地址 -u用户名 -p(登陆用户密码) # 修改用户密码 mysqladmin # mysqladmin -u root ...
- Linux虚拟机添加硬盘
任务:添加1块硬盘,并且分1个区,挂载到/bak 第一.插上硬盘 第二.分区 第三.格式化(定义:文件系统的类型) FAT,FAT32,NTFS,ext1,ext2,ext3,ext4,.... 第 ...
- sin之舞---蓝桥杯练习
问题描述 最近FJ为他的奶牛们开设了数学分析课,FJ知道若要学好这门课,必须有一个好的三角函数基本功.所以他准备和奶牛们做一个“Sine之舞”的游戏,寓教于乐,提高奶牛们的计算能力. 不妨设 An=s ...
- 0x06 - Nginx 负载均衡会话保持
Nginx 负载均衡会话保持 背景 负载均衡时,如果APP需要保持特定状态的时候,就要保证同一用户的 session 会被分配到同一台服务器上. 实现方案 使用cookie 将用户的 session ...
- 2013 ACM网络搜索与数据挖掘国际会议
ACM网络搜索与数据挖掘国际会议" title="2013 ACM网络搜索与数据挖掘国际会议"> 编者按:ACM网络搜索与数据挖掘国际会议(6th ACM Conf ...
- 一:MYsql登录,服务开启和停止
字段的属性: 1:名称 2:数据类型 3:长度 4:约束 SQL的分类:(结构化查询语言) 1:数据查询语言DQL select 2:数据操纵语言DML insert delete u ...
- HotSpot Java对象创建,内存布局以及访问方式
内存中对象的创建.对象的结构以及访问方式. 一.对象的创建 在语言层面上,对象的创建只不过是一个new关键字而已,那么在虚拟机中又是一个怎样的过程呢? (一)判断类是否加载.虚拟机遇到一条new指令的 ...
- 微软科学家Leslie Lamport荣获2013年图灵奖
Lamport荣获2013年图灵奖" title="微软科学家Leslie Lamport荣获2013年图灵奖"> 编者按:Leslie Lamport,新晋图灵奖 ...
- dtree加载菜单基本使用方法
步骤1:官网下载dtree.zip包,官网地址:http://destroydrop.com/javascripts/tree/,文件包括dtree.css,dtree.js和api.html和例子: ...