码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 1242——Rescue(优先队列)

时间:2014-07-30 17:45:04      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:style   color   os   strong   io   for   ar   时间   

题意:

一个天使a被关在迷宫里,她的许多小伙伴r打算去救她,求小伙伴就到她需要的最小时间。在迷宫里有守卫,打败守卫需要一个单位时间,如果碰到守卫必须要杀死他

思路:

天使只有一个,她的小伙伴有很多,所以可以让天使找她的小伙伴,一旦找到小伙伴就renturn。时间小的优先级高。优先队列搞定


#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define fx(i,xi,n) for(int i=xi;i<n;++i)
#define ms(s,i) memset(s,i,sizeof (s))

using namespace std;
int dir[4][2]={0,1,0,-1,1,0,-1,0},vis[210][210],flag,ans,n,m;
char map[210][210];
bool check(int x,int y){if(x>=0&&x<n&&y>=0&&y<m&&!vis[x][y]&&map[x][y]!='#')return true;return false;}
struct pp{int x,y,s;friend bool operator<(const pp a,const pp b){return a.s>b.s;}};
void bfs(int x,int y)
{
    priority_queue<pp> q;
    pp a,b;
    a.x=x;a.y=y;a.s=0;ms(vis,0);vis[x][y]=1;
    q.push(a);
    while(!q.empty()){
        a=q.top();q.pop();
//        cout<<a.x<<" "<<a.y<<map[a.x][a.y]<<endl;
        fx(i,0,4){
            b.x=a.x+dir[i][0];b.y=a.y+dir[i][1];
            if(check(b.x,b.y)){
                vis[b.x][b.y]=1;b.s=a.s+1;
                if(map[b.x][b.y]=='r'){flag=1;ans=b.s;return ;}
                if(map[b.x][b.y]=='x') {b.s++;}
                q.push(b);
            }
        }
    }
}
int main()
{
    while(scanf("%d%d",&n,&m)!=EOF){
    ms(map,'#');
    fx(i,0,n) scanf("%s",map[i]);
    int sx,sy;
    fx(i,0,n)fx(j,0,m){if(map[i][j]=='a'){sx=i;sy=j;}}
    flag=ans=0;
    bfs(sx,sy);
    if(flag) cout<<ans<<endl;
    else cout<<"Poor ANGEL has to stay in the prison all his life."<<endl;
    }
    return 0;
}




HDU 1242——Rescue(优先队列),布布扣,bubuko.com

HDU 1242——Rescue(优先队列)

标签:style   color   os   strong   io   for   ar   时间   

原文地址:http://blog.csdn.net/u014141559/article/details/38300509

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!