题目传送门

题意:从r走到a,遇到x多走一步,问最小走到a的步数

分析:因为r有多个,反过来想从a走到某个r的最小步数,简单的BFS。我对这题有特殊的感情,去年刚来集训队时肉鸽推荐了这题,当时什么都不会,看个数组模拟队列的BFS看的头晕,现在看起来也不过如此,额,当年开始是从r走到a的,因为数据巨弱才过的,应该要用到优先队列。

/************************************************
* Author :Running_Time
* Created Time :2015/9/25 星期五 09:13:51
* File Name :B_BFS.cpp
************************************************/ #include <cstdio>
#include <algorithm>
#include <iostream>
#include <sstream>
#include <cstring>
#include <cmath>
#include <string>
#include <vector>
#include <queue>
#include <deque>
#include <stack>
#include <list>
#include <map>
#include <set>
#include <bitset>
#include <cstdlib>
#include <ctime>
using namespace std; #define lson l, mid, rt << 1
#define rson mid + 1, r, rt << 1 | 1
typedef long long ll;
const int N = 2e2 + 10;
const int INF = 0x3f3f3f3f;
const int MOD = 1e9 + 7;
const double EPS = 1e-8;
struct Angle {
int x, y, step;
Angle () {}
Angle (int x, int y, int step) : x (x), y (y), step (step) {}
};
int dx[4] = {-1, 1, 0, 0};
int dy[4] = {0, 0, -1, 1};
bool vis[N][N];
char maze[N][N];
int n, m; bool judge(int x, int y) {
if (x < 1 || x > n || y < 1 || y > m || vis[x][y] || maze[x][y] == '#') return false;
else return true;
} void BFS(Angle s) {
int ret = INF;
memset (vis, false, sizeof (vis));
queue<Angle> Q; Q.push (s);
vis[s.x][s.y] = true;
while (!Q.empty ()) {
Angle r = Q.front (); Q.pop ();
for (int i=0; i<4; ++i) {
int tx = r.x + dx[i];
int ty = r.y + dy[i];
if (!judge (tx, ty)) continue;
vis[tx][ty] = true;
if (maze[tx][ty] == 'r') {
ret = min (ret, r.step + 1); continue;
}
else if (maze[tx][ty] == 'x') {
Q.push (Angle (tx, ty, r.step + 2)); continue;
}
else Q.push (Angle (tx, ty, r.step + 1));
}
}
if (ret == INF) puts ("Poor ANGEL has to stay in the prison all his life.");
else printf ("%d\n", ret);
} int main(void) {
while (scanf ("%d%d", &n, &m) == 2) {
for (int i=1; i<=n; ++i) {
scanf ("%s", maze[i] + 1);
}
bool find = false; Angle start;
for (int i=1; i<=n && !find; ++i) {
for (int j=1; j<=m; ++j) {
if (maze[i][j] == 'a') {
start = Angle (i, j, 0);
find = true; break;
}
}
}
BFS (start);
} return 0;
}

当年的代码不忍直视。。。

#include<stdio.h>
typedef struct point
{
int x,y,step;
}target;
int N,M,dir[4][2]={0,1,0,-1,1,0,-1,0},ax,ay;
int flag[202][202];
char map[302][302];
target que[40005];
int BFS(target start)
{
int end,top,i;
int min=1000000;
target in,next;
end=top=0;
que[top]=start;
while (top>=end)
{
in=que[end];
end=(end+1);
for (i=0;i<4;i++)
{
next.x=in.x+dir[i][0];
next.y=in.y+dir[i][1];
if (map[next.x][next.y]=='r')
{
if (min>in.step+1)
min=in.step+1;
}
if (next.x>=0&&next.x<N&&next.y>=0&&next.y<M&&map[next.x][next.y]!='#')
{
if (flag[next.x][next.y]>in.step+1)
{
next.step=in.step+1;
if (map[next.x][next.y]=='x')
next.step++;
flag[next.x][next.y]=next.step;
top=(top+1);
que[top]=next;
}
}
}
}
if (min!=1000000)return min;
else
return -1;
}
int main()
{
int i,j,num;
target start;
while (scanf("%d%d",&N,&M)!=EOF)
{
for (i=0;i<N;i++)
{
scanf("%s",map[i]);
for (j=0;j<M;j++)
{
flag[i][j]=1000000;
if (map[i][j]=='a')
{
//map[i][j]='.';
ax=i;
ay=j;
}
}
}
start.x=ax;
start.y=ay;
start.step=0;
//map[ax][ay]='.';
num=BFS(start);
if (num==-1)
printf("Poor ANGEL has to stay in the prison all his life.\n");
else
printf("%d\n",num);
}
return 0;
}

  

BFS HDOJ 1242 Rescue的更多相关文章

  1. hdoj 1242 Rescue

    Rescue Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  2. HDOJ/HDU 1242 Rescue(经典BFS深搜-优先队列)

    Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The prison is ...

  3. hdu 1242:Rescue(BFS广搜 + 优先队列)

    Rescue Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submis ...

  4. hdu - 1242 Rescue && hdu - 2425 Hiking Trip (优先队列+bfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=1242 感觉题目没有表述清楚,angel的朋友应该不一定只有一个,那么正解就是a去搜索r,再用普通的bfs就能过了 ...

  5. HDU 1242 Rescue (BFS(广度优先搜索))

    Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

  6. hdu 1242 Rescue(bfs)

    此刻再看优先队列,不像刚接触时的那般迷茫!这也许就是集训的成果吧! 加油!!!优先队列必须要搞定的! 这道题意很简单!自己定义优先级别! +++++++++++++++++++++++++++++++ ...

  7. HDU 1242 Rescue(BFS+优先队列)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1242 题目描述: Problem Description Angel was caught by t ...

  8. hdu 1242 Rescue (BFS)

    Rescue Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  9. HDU 1242 -Rescue (双向BFS)&amp;&amp;( BFS+优先队列)

    题目链接:Rescue 进度落下的太多了,哎╮(╯▽╰)╭,渣渣我总是埋怨进度比别人慢...为什么不试着改变一下捏.... 開始以为是水题,想敲一下练手的,后来发现并非一个简单的搜索题,BFS做肯定出 ...

随机推荐

  1. HDOJ--1869--六度分离(用三种算法写的,希望能比較出来他们之间的差别)

    六度分离 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  2. Golang-interface(二 接口与nil)

    github: https://github.com/ZhangzheBJUT/blog/blob/master/nil.md 一 接口与nil 前面解说了go语言中接口的基本用法,以下将说一说nil ...

  3. mybatis xml文件解析

    1 parameterType 如果参数只有一个,比如一个id,即int类型的id,那么parameterType直接是int. 如果参数有多个,那么就用表中一行对应的类,默认是类的名字和表中列的名字 ...

  4. python dictionary的遍历

    d = {'x':1, 'y':3, 'z':2} for k in d:    print d[k] 直接遍历k in d的话,遍历的是dictionary的keys. 2 字典的键可以是任何不可变 ...

  5. 小程序 单页应用的 tab切换 实现

    小程序 单页应用的  tab切换 实现

  6. CLI和CGI的区别

    CGI :“公共网关接口”(Common Gateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上.以CGI方式运行时,web s ...

  7. PHP获取类名及所有函数名

    PHP获取当前类名.方法名  __CLASS__ 获取当前类名  __FUNCTION__ 当前函数名(confirm)  __METHOD__ 当前方法名 (bankcard::confirm) _ ...

  8. webpack 的编译原理

    自从接触了react,vue 这两个框架,都会用到webpack这个打包工具.面试的时候,经常被问到知道webpack的编译原理吗? 可以简单的介绍一下.每每这个时候都被问的哑口无言,平时用的时候挺顺 ...

  9. POJ3045 Cow Acrobats —— 思维证明

    题目链接:http://poj.org/problem?id=3045 Cow Acrobats Time Limit: 1000MS   Memory Limit: 65536K Total Sub ...

  10. python中的编码和解码

    计算机中常见的编码方式有多种,英文一般是ascii编码,其他有unicode,utf-8,gbk,utf-16等编码. 常见编码方式: ASCII编码:ASCII是早期的编码,包含英文字母.数字和 ...