HDU 1242——Rescue(优先队列)

题意:

一个天使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;
}




posted @ 2016-01-10 20:00  zfyouxi  阅读(154)  评论(0编辑  收藏  举报