迷宫问题
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

一个5 × 5的二维数组,表示一个迷宫。数据保证有唯一解。

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+路径记录】的更多相关文章

  1. [POJ 3984] 迷宫问题(BFS最短路径的记录和打印问题)

    题目链接:http://poj.org/problem?id=3984 宽度优先搜索最短路径的记录和打印问题 #include<iostream> #include<queue> ...

  2. 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, ...

  3. POJ 3984 迷宫问题 bfs 难度:0

    http://poj.org/problem?id=3984 典型的迷宫问题,记录最快到达某个点的是哪个点即可 #include <cstdio> #include <cstring ...

  4. POJ 3984 - 迷宫问题 - [BFS水题]

    题目链接:http://poj.org/problem?id=3984 Description 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, ...

  5. poj 3984 迷宫问题 bfs

    学会这道水题之后我懂得了不少哈,首先水题也能学到不少知识,尤其像我这样刚入门的小菜鸟,能学到一些小技巧. 然后就是可以从别人的代码里学到不一样的思路和想法. 这题就是求最短的路径,首先想到就是用bfs ...

  6. POJ 3984 迷宫问题 (BFS + Stack)

    链接 : Here! 思路 : BFS一下, 然后记录下每个孩子的父亲用于找到一条路径, 因为寻找这条路径只能从后向前找, 这符合栈的特点, 因此在输出路径的时候先把目标节点压入栈中, 然后不断的向前 ...

  7. POJ - 3984 迷宫问题 bfs解法

    #include<stdio.h> #include<string.h> #include<algorithm> #include<stack> usi ...

  8. BFS(最短路+路径打印) POJ 3984 迷宫问题

    题目传送门 /* BFS:额,这题的数据范围太小了.但是重点是最短路的求法和输出路径的写法. dir数组记录是当前点的上一个点是从哪个方向过来的,搜索+,那么回溯- */ /************* ...

  9. POJ 3984 迷宫问题(简单bfs+路径打印)

    传送门: http://poj.org/problem?id=3984 迷宫问题 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions ...

  10. (简单) 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, ...

随机推荐

  1. Load a script file in sencha, supports both asynchronous and synchronous approaches

    //http://www.sencha.com/forum/showthread.php?188318-Ext.Loader.loadScriptFile-wrong-URL Ext.Loader.l ...

  2. Memcached(五)Memcached的并发实例

    package com.sinosuperman.memcached; import java.io.IOException; import java.net.InetSocketAddress; i ...

  3. python 文件查找 glob

    glob模块是最简单的模块之一,内容非常少.用它可以查找符合特定规则的文件路径名.跟使用windows下的文件搜索差不多.查找文件只用到三个匹配符:"*", "?&quo ...

  4. mysql的错误:The server quit without updating PID file /usr/local/mysql/data/door.pid).

    mysql错误解决: 先 参考:http://www.jb51.net/article/48625.htm 参考第四条: mysql在启动时没有指定配置文件时会使用/etc/my.cnf配置文件,请打 ...

  5. matlab高斯模板生成,K是归一化系数,上面是一个半径200的高斯模板用来做MSR

    R3=; F=zeros(*R3+,*R3+); sigma=R3/; r=; :*R3+     :*R3+         r=(x-R3)*(x-R3)+(y-R3)*(y-R3);       ...

  6. .NET中的加密算法总结(自定义加密Helper类续)

    1.1.1 摘要 相信许多人都使用过.NET提供的加密算法,而且在使用的过程我们必须了解每种加密算法的特点(对称或非对称,密钥长度和初始化向量等等).我也看到过很多人写过.NET中加密算法总结,但我发 ...

  7. Fiddler对安卓应用手机抓包图文教程

    http://www.cr173.com/html/37625_1.html 做开发需要抓取手机app的http/https的数据包,想看APP发出的http请求和响应是什么,这就需要抓包了,这可以得 ...

  8. Protel封装库

    一.目录下面的一些封装库中,根据元件的不同封装我们将其封装分为二大类:一类是分立元件的封装,一类是集成电路元件的封装 1.分立元件类: 电容:电容分普通电容和贴片电容: 普通电容在Miscellane ...

  9. Android TabActivity与Activity之间的动画跳转(主要Tabhost中跳转出来的动画效果解决)

    首先,要说的是ActivityA到ActivityB的切换这个相对简单,只要overridePendingTransition(In,out). 这里不就说了.但是这里要说名的ActivityA不能T ...

  10. Android 常用UI控件之TabHost(1)TabHost的两种布局方式

    TabHost是Android中的tab组件. TabHost布局文件的基本结构 TabHost下有个layout,这个layout中有TabWidget与FrameLayout.TabWidget是 ...