poj 3984 迷宫问题【bfs+路径记录】
Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 10103 | Accepted: 6005 |
Description
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, 0,
};
它表示一个迷宫,其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的最短路线。
Input
Output
Sample Input
0 1 0 0 0
0 1 0 1 0
0 0 0 0 0
0 1 1 1 0
0 0 0 1 0
Sample Output
(0, 0)
(1, 0)
(2, 0)
(2, 1)
(2, 2)
(2, 3)
(2, 4)
(3, 4)
(4, 4) 输出路径的方法为从终点倒退到起点 观察规律可知当前步的上一步必定是只能改变一个方向的值所以只有横坐标变或者只有纵坐标变所以可以确定下当前步上一步的位置(当步数相同时可以确定上一步的位置)自己想的代码 大神勿喷
#include<stdio.h>
#include<string.h>
#include<queue>
#define MAX 5000
using namespace std;
int map[5][5];
int n,m;
int bu[100][100];
int s[MAX];//记录位置的横坐标
int s1[MAX];//记录位置的纵坐标
struct node
{
int x,y;
int step;
friend bool operator < (node a,node b)
{
return a.step>b.step;
}
};
int bfs(int x1,int y1,int x2,int y2)
{
int i,j,ok=0,k,t=1;
int move[4][2]={0,1,0,-1,1,0,-1,0};
priority_queue<node>q;
node beg,end;
beg.x=x1;
beg.y=y1;
q.push(beg);
while(!q.empty())
{
end=q.top();
q.pop();
if(end.x==x2&&end.y==y2)
{
break;
}
for(i=0;i<4;i++)
{
beg.x=end.x+move[i][0];
beg.y=end.y+move[i][1];
if(0<=beg.x&&beg.x<5&&0<=beg.y&&beg.y<5&&map[beg.x][beg.y]==0)
{
map[beg.x][beg.y]=1;
beg.step=end.step+1;
bu[beg.x][beg.y]=beg.step;//记录对应步数时的节点位置
q.push(beg);
}
}
}
s[0]=4;s1[0]=4;//初值为终点,倒着打印出最短路径
for(i=end.step-1;i>=0;i--)
{
for(j=0;j<5;j++)
{
for(k=0;k<5;k++)
{
if(bu[j][k]==i)
{
if((j==s[t-1]-1&&k==s1[t-1])||(k==s1[t-1]-1&&j==s[t-1]))//观察规律可知当前步的上一步必定是只能改变
{ //一个方向的值所以只有横坐标变或者只有纵坐标变
s[t]=j; //记录下路径
s1[t]=k;
t++;
}
}
}
}
}
printf("(0, 0)\n");
for(i=t-1;i>=0;i--)
{
printf("(%d, %d)\n",s[i],s1[i]);
}
}
int main()
{
int i,j,k,sum;
for(i=0;i<5;i++)
for(j=0;j<5;j++)
scanf("%d",&map[i][j]);
memset(bu,0,sizeof(bu));
bfs(0,0,4,4);
return 0;
}
#include<stdio.h>
#include<string.h>
#include<queue>
#define MAX 210
using namespace std;
int map[6][6];
struct node
{
int x,y;
int time;
friend bool operator < (node a,node b)
{
return a.time>b.time;
}
};
int a[MAX],b[MAX];
void bfs(int x1,int y1,int x2,int y2)
{
int i,j,ok=0,k=0;
priority_queue<node>q;
int move[4][2]={0,1,0,-1,1,0,-1,0};
node beg,end;
beg.x=x1;
beg.y=y1;
beg.time=0;
q.push(beg);
while(!q.empty())
{
end=q.top();
q.pop();
if(end.x==x2&&end.y==y2)
{
ok=1;
break;
}
for(i=0;i<4;i++)
{
beg.x=end.x+move[i][0];
beg.y=end.y+move[i][1];
if(beg.x>=0&&beg.x<5&&beg.y>=0&&beg.y<5&&map[beg.x][beg.y]!=1)
{
beg.time=end.time+1;
a[k]=beg.x;
b[k++]=beg.y;
map[beg.x][beg.y]=1;
q.push(beg);
}
}
}
if(ok)
{
printf("(0, 0)\n");
int d=0,e=0;
for(i=0;i<k;i++)
{
if(a[i]==d&&b[i]==e+1||a[i]==d+1&&b[i]==e)
{
d=a[i];
e=b[i];
printf("(%d, %d)\n",a[i],b[i]);
}
} }
}
int main()
{
int i,j;
int x1,y1,x2,y2;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
{
scanf("%d",&map[i][j]);
}
}
bfs(0,0,4,4);
return 0;
}
poj 3984 迷宫问题【bfs+路径记录】的更多相关文章
- [POJ 3984] 迷宫问题(BFS最短路径的记录和打印问题)
题目链接:http://poj.org/problem?id=3984 宽度优先搜索最短路径的记录和打印问题 #include<iostream> #include<queue> ...
- 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, ...
- POJ 3984 迷宫问题 bfs 难度:0
http://poj.org/problem?id=3984 典型的迷宫问题,记录最快到达某个点的是哪个点即可 #include <cstdio> #include <cstring ...
- POJ 3984 - 迷宫问题 - [BFS水题]
题目链接:http://poj.org/problem?id=3984 Description 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, ...
- poj 3984 迷宫问题 bfs
学会这道水题之后我懂得了不少哈,首先水题也能学到不少知识,尤其像我这样刚入门的小菜鸟,能学到一些小技巧. 然后就是可以从别人的代码里学到不一样的思路和想法. 这题就是求最短的路径,首先想到就是用bfs ...
- POJ 3984 迷宫问题 (BFS + Stack)
链接 : Here! 思路 : BFS一下, 然后记录下每个孩子的父亲用于找到一条路径, 因为寻找这条路径只能从后向前找, 这符合栈的特点, 因此在输出路径的时候先把目标节点压入栈中, 然后不断的向前 ...
- POJ - 3984 迷宫问题 bfs解法
#include<stdio.h> #include<string.h> #include<algorithm> #include<stack> usi ...
- BFS(最短路+路径打印) POJ 3984 迷宫问题
题目传送门 /* BFS:额,这题的数据范围太小了.但是重点是最短路的求法和输出路径的写法. dir数组记录是当前点的上一个点是从哪个方向过来的,搜索+,那么回溯- */ /************* ...
- POJ 3984 迷宫问题(简单bfs+路径打印)
传送门: http://poj.org/problem?id=3984 迷宫问题 Time Limit: 1000MS Memory Limit: 65536K Total Submissions ...
- (简单) POJ 3984 迷宫问题,BFS。
Description 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, ...
随机推荐
- 敏捷开发概述与路线(转自MBAlib)
敏捷开发的概述 简单的说,敏捷开发是一种以人为核心.迭代.循序渐进的开发方法.在敏捷开发中,软件项目的构建被切分成多个子项目,各个子项目的成果都经过测试,具备集成和可运行的特征.换言之,就是把一个大项 ...
- 让Eclipse使用新版本的JRE
更新到新的 Mac OS X 再打开Eclipse 编译程序会报错, Exception in thread "main" java.lang.UnsupportedClassVe ...
- HDU 2369 Broken Keyboard(字符串)
点我看题目 题意 : 这个人的键盘坏了,最多只能按n个键,给你一串字符串,问你找一个最长的字串,这个字串中包含的不同的字母不能超过n个. 思路 : 比赛的时候脑子没转过来,一直没模拟出来,都不知道怎么 ...
- C#中使用正则表达式提取超链接地址的集中方法(转)
一般在做爬虫或者CMS的时候经常需要提取 href链接或者是src地址.此时可以使用正则表达式轻松完成. Regex reg = new Regex(@"(?is)<a[^>]* ...
- 对TCP/IP网络协议的深入浅出归纳(转)
前段时间做了一个开发,涉及到网络编程,开发过程比较顺利,但任务完成后始终觉得有一些疑惑.主要是因为对网络协议不太熟悉,对一些概念也没弄清楚.后来 我花了一些时间去了解这些网络协议,现在对TCP/IP网 ...
- java的几种for循环方法
自从jdk升级为1.8以后,for循环又升级了 classic for classic foreach List.forEach() List.stream().forEach() List.para ...
- IQ Test
IQ Test Description: Bob is preparing to pass IQ test. The most frequent task in this test is to fin ...
- 转:理解 Linux 的硬链接与软链接
Linux 的文件与目录 现代操作系统为解决信息能独立于进程之外被长期存储引入了文件,文件作为进程 创建信息的逻辑单元可被多个进程并发使用.在 UNIX 系统中,操作系统为磁盘上的文本与图像.鼠标与键 ...
- XCode中Architecturs配置及常见问题
http://lanvige.github.io/2014/03/19/architecturs-in-xcode/ XCode 5.1升级后因arm64和CocoaPods的原因,痛了一天,终于解决 ...
- 不是 EPUB ,而是 ePub
ePub 是 Electronic Publication 的缩写,意为电子出版,是一个自由的开放标准,属于一种可以“自动重新编排”的内容,也就是文字内容可以根据阅读设备的特性,以最适于阅读的方式显示 ...