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, ...
随机推荐
- 常用的四种CSS样式表格
1. 单像素边框CSS表格 这是一个很常用的表格样式. [html] <style type="text/css"> table.gridtable { font-fa ...
- gradient css
<!DOCTYPE html> <html> <head> <title></title> <script src="js/ ...
- poj 1348 Computing (四个数的加减乘除四则运算)
http://poj.org/problem?id=1348 Computing Time Limit: 1000MS Memory Limit: 10000K Total Submissions ...
- 开发错误日志之FTP协议传输文件问题
从开发端用FTP协议向服务器(Linux系统)传输文件时,cat -A查询文件内容中行尾会有^M出现. 解决方案:改用SFTP协议上传文件.
- Docker 监控- Prometheus VS Cloud Insight
如今,越来越多的公司开始使用 Docker 了,2 / 3 的公司在尝试了 Docker 后最终使用了它.为了能够更精确的分配每个容器能使用的资源,我们想要实时获取容器运行时使用资源的情况,怎样对 D ...
- RPM包制作最简单样例
相关开发RPM的包要安装 Summary: the Firt RPM of Sky Name: hellow Version: 0.1 Release: Vendor: PA soft(aguncn@ ...
- PHP unlink() 函数
定义和用法 unlink() 函数删除文件. 若成功,则返回 true,失败则返回 false. 语法 unlink(filename,context) 参数 描述 filename 必需.规定要删除 ...
- java static 变量,和方法从属于类
第36集 java static 变量,和方法从属于类 可以用类来直接调用static属性和方法 static方法不能调用非静态的属性和方法,反之可以 new产生的对象,不包括static 属性和方法
- 目标识别:Bag-of-words表示图像
BOW (bag of words) 模型简介 Bag of words模型最初被用在文本分类中,将文档表示成特征矢量.它的基本思想是假定对于一个文本,忽略其词序和语法.句法,仅仅将其看做是一些词汇的 ...
- linux是实时系统还是分时操作系统
实时操作系统 实时操作系统 英文称Real Time Operating System,简称RTOS. 1.实时操作系统定义 实时操作系统(RTOS)是指当外界事件或数据产生时,能够接受并以足够快的速 ...