PTA-迷宫寻路(输出最短路径)
给定一个M行N列的迷宫图,其中 "0"表示可通路,"1"表示障碍物,无法通行。在迷宫中只允许在水平或上下四个方向的通路上行走,走过的位置不能重复走。
5行8列的迷宫如下:
则从左上角(1,1)至右下角(5,8)的最短路径为:
1,1--》2,1--》2,2--》2,3--》3,3--》3,4--》3,5--》4,5--》5,5--》5,6--》5,7--》5,8
题目保证每个迷宫最多只有一条最短路径。
请输出该条最短路径,如果不存在任何通路,则输出"NO FOUND".
输入格式:
第一行,输入M和N值,表示迷宫行数和列数。
接着输入M行数值,其中,0表示通路,1表示障碍物。每列数值用空格符间隔。
接下来可能输入多组迷宫数据。
当输入M的值为-1时结束输入。
输出格式:
按行顺序输出路径的每个位置的行数和列数,如 x,y
如果不存在任何路径,则输出"NO FOUND".
每组迷宫寻路结果用换行符间隔。
输入样例:
在这里给出一组迷宫。例如:
8 8
0 0 1 0 0 0 1 0
0 0 1 0 0 0 1 0
0 0 0 0 1 1 0 0
0 1 1 1 0 0 0 0
0 0 0 1 0 0 0 0
0 1 0 0 0 1 0 0
0 1 1 1 0 1 1 0
1 0 0 0 0 0 0 0
4 4
0 0 1 0
0 0 0 0
0 0 1 1
0 1 0 0
-1 -1
输出样例:
在这里给出相应的输出。例如:1,1
,
,
,
,
,
,
,
,
,
,
,
,
,
, NO FOUND
【答案,虽然是满分,但健壮性不一定,不想奋斗的,随意复制粘贴吧!】
#include <bits/stdc++.h>
using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
class node
{
public:
int x,y;
node()
{ }
node(int ax,int ay)
{
x=ax;
y=ay;
}
};
int mv[][]={{,},{,-},{,},{-,}};
int vis[][];
int pre[][];
int main(int argc, char *argv[]) {
int m,n;
int aa=;
cin>>m>>n;
while(m!=-)
{
memset(vis,m*n,);
memset(pre,m*n,);
vector<vector<int> > v;
for(int i=;i<m;i++)
{
vector<int> t;
v.push_back(t);
for(int j=;j<n;j++)
{
int ta;
cin>>ta;
v[i].push_back(ta);
}
} queue<node> q;
q.push(node(,));
vis[][]=;
int f=;
while(!q.empty())
{
node qf = q.front();
if(qf.x==m-&&qf.y==n-)
{
f=; break; }
q.pop();
for(int i=;i<;i++)
{
node tt(qf.x+mv[i][],qf.y+mv[i][]);
if((tt.x>=&&tt.x<m&&tt.y>=&&tt.y<n)&&!vis[tt.x][tt.y]&&!v[tt.x][tt.y])
{
vis[tt.x][tt.y] =;
pre[tt.x][tt.y] =qf.x*n+qf.y;
q.push(tt);
//cout<<tt.x<<" "<<tt.y<<endl;
}
}
}
if(f)
{
stack<node> sn;
int xy = pre[m-][n-];
while(xy)
{ sn.push(node(xy/n+,xy%n+));
xy = pre[xy/n][xy%n];
}
cout<<"1,1"<<endl; while(!sn.empty())
{
cout<<sn.top().x<<","<<sn.top().y<<endl;
sn.pop();
}
cout<<m<<","<<n<<endl<<endl; }else
{
cout<<"NO FOUND"<<endl;
}
cin>>m>>n;
} return ;
}
【献给那些努力奋斗的同学儿,努力学习为国争光!】
#include <iostream>
#include <string.h>
using namespace std;
/*
*迷宫最短路径
*迷宫数组是从1 开始
*/
int n,m,p,q,Min=;//迷宫n行m列,出口位置(p,q)
int a[][]={};//迷宫数组
int book[][]={};//标记是否走过
int next[][]={{,},{,},{,-},{-,}};//向下,向右,向上,向左 int stepA[][]={-};//记录当前路径
int stepB[][]={-};//记录最小路径 void dfs(int x,int y,int step)
{
int tx,ty,k;
if(x==p&&y==q)
{
if(step<Min)
{
for(int t=;t<;t++)
{
if(stepA[t][]==-&&stepA[t][]==-)
{
break;
}
stepB[t][]=stepA[t][];
stepB[t][]=stepA[t][];
} Min=step;
}
return;
} for(k=;k<=;k++)
{
//计算下一点的坐标
tx=x+next[k][];
ty=y+next[k][];
if(tx<||tx>n||ty<||ty>m)
continue; if(a[tx][ty]==&&book[tx][ty]==)
{
stepA[step][]=tx;
stepA[step][]=ty; book[tx][ty]=;//标记已经走过了这个点
dfs(tx,ty,step+);//尝试下一个点
book[tx][ty]=;//取消这个点的标记
}
}
return;
}
int main()
{
int startx=,starty=;
cout<<"请输入迷宫的大小(行、列):"<<endl;
cin>>n>>m;
cout<<"请输入迷宫布局('0'代表通路,'1'代表墙):"<<endl;
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
cin>>a[i][j];
}
}
cout<<"请输入起点与终点坐标:" <<endl;
cin>>startx>>starty>>p>>q;
book[startx][starty]=;
dfs(startx,starty,);
if(Min==)//没有最短路径就说明没有通路
{
cout<<'\n'<<"【提示】两点之间没有通路!"<<endl;
return ;
}
cout<<"走出迷宫最少步数:"<<endl;
cout<<Min<<endl;
cout<<"迷宫最短路径:"<<endl;
for(int t=;t<Min;t++)
{
if(t==)
cout<< startx<<" "<<starty<<endl;
cout<<stepB[t][]<<" "<<stepB[t][]<<endl; }
return ;
}
代码截图:【帅不帅气,一给我里giaogiao】



PTA-迷宫寻路(输出最短路径)的更多相关文章
- PTA7-1 迷宫寻路 (20分)
7-1 迷宫寻路 (20分) 给定一个M行N列的迷宫图,其中 "0"表示可通路,"1"表示障碍物,无法通行.在迷宫中只允许在水平或上下四个方向的通路上行走,走过 ...
- C++ 迷宫寻路问题
迷宫寻路应该是栈结构的一个非常经典的应用了, 最近看数据结构算法应用时看到了这个问题, 想起来在校求学时参加算法竞赛有遇到过相关问题, 感觉十分亲切, 在此求解并分享过程, 如有疏漏, 欢迎指正 问题 ...
- POJ - 3984迷宫问题(最短路径输出)
题目链接:http://poj.org/problem?id=3984 题目: 迷宫问题 Time Limit: 1000MS Memory Limit: 65536K Total Submiss ...
- - 迷宫问题 POJ - 3984 bfs记录路径并输出最短路径
定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, ...
- 51 NOd 1459 迷宫游戏 (最短路径)
1459 迷宫游戏 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间, ...
- [POJ 3984] 迷宫问题(BFS最短路径的记录和打印问题)
题目链接:http://poj.org/problem?id=3984 宽度优先搜索最短路径的记录和打印问题 #include<iostream> #include<queue> ...
- dijkstra算法计算最短路径和并输出最短路径
void dijisitela(int d, int m1) { ], book[], path[], u, v, min; l = ; ; i < n1; i++) { dis[i] = w[ ...
- PTA 中序输出叶子结点
6-8 中序输出叶子结点 (10 分) 本题要求实现一个函数,按照中序遍历的顺序输出给定二叉树的叶结点. 函数接口定义: void InorderPrintLeaves( BiTree T); T ...
- NEFU 558 迷宫寻路
题目链接 简单搜索题 #include <cstdio> #include <iostream> #include <cstring> using namespac ...
随机推荐
- 最近公共祖先LCA(Tarjan算法)的思考和算法实现——转载自Vendetta Blogs
LCA 最近公共祖先 Tarjan(离线)算法的基本思路及其算法实现 小广告:METO CODE 安溪一中信息学在线评测系统(OJ) //由于这是第一篇博客..有点瑕疵...比如我把false写成了f ...
- Binary Protocol
A. Binary Protocol 这道题要唯一注意的一点就是数字0的表示--0个"1"来表达,所以字符串"100"所表示的数字就是100 附代码: // C ...
- Linux 搭建Mysql主从节点复制
Linux环境 Centos 6.6 64位 准备两台服务器,搭建一主一从,实现Mysql的读写分离和数据备份 主节点 192.168.43.10 leader 从节点 192.168.43.20 d ...
- kafka 性能测试脚本
[参考文章]:Kafka自带的性能测试脚本 1. 生产消息压测脚本 1.1 脚本及参数 bin/kafka-producer-perf-test.sh --topic kafka-test-0 -- ...
- linux升级安装openssh时出现依赖冲突
通过如下方式下载到openssh安装包 https://www.cnblogs.com/qq931399960/p/11120429.html -rwxrwxrwx. root root Jul : ...
- For 循环 kotlin(10)
For 循环 for 循环可以对任何提供迭代器(iterator) 的对象进行遍历,语法如下: for (item in collection) print(item) 循环体可以是一个代码块. fo ...
- GitHub:Baidu
ylbtech-GitHub:Baidu 1.返回顶部 · duedge-recipes DuEdge百度边缘网络计算样例代码 edgeedge-computingduedge JavaScri ...
- MEF部件的生命周期(PartCreationPolicy)
一.演示概述 本演示介绍了MEF的生命周期管理,重点介绍了导出部件的三种创建策略,分别是:CreationPolicy.Any.CreationPolicy.Shared.CreationPolicy ...
- 阶段3 3.SpringMVC·_07.SSM整合案例_06.ssm整合之编写MyBatis框架
需要先搭建Mybits的环境. 用Mybits的注解的方式.把两个方法的sql语句写完 SqlMapConfig.xml resources下新建xml文档 把约束粘贴过来 两步操作 环境标签叫做en ...
- Ubuntu上挂载源代码,docker容器中共享这个原代码,实现自动部署
https://www.jianshu.com/p/23465dc86d3e 地址 5.3. 挂载源代码 为了在宿主机上创建.NET Core 项目,这个时候我们就需要在Linux宿主机上安装.N ...