cqy终于算出了坑爹的密码!!!进入墓穴,发现墓穴是一个n*m的矩阵。由于墓穴极度缺氧,cqy必须用最短的时间找到唯一的宝藏。墓穴里险象环生,除了有各种各样的陷阱,还有野怪出没!!!cqy每前进一步需要1分钟的时间,如果遇到野怪,还要多花费1分钟来打倒野怪。当然cqy不会往陷阱走,那就有去无回了…如果cqy、宝藏、陷阱、野怪的位置全部已知,那么cqy最短要用多长时间找到宝藏?
输入 有多组测试数据。对于每组测试数据,首先有两个整数n和m(1<n,m<50),接下来有n行,每行有m个字符,A表示宝藏,C表示cqy,E表示正常的道路,X表示陷阱,T表示野怪。
输出
对于每组测试数据,在一行内输出找到宝藏所需的最短时间,如果无法找到宝藏,则输出“Game Over!”
输入: 输出:
4 4 2 3 5
ATTE CXE Game Over!
EXTE TXA
ETCE
EXEX
青杨大神出的BFS+优先队列神题, 刚开始看题,一看就知道是以前做过的BFS水题,但是怎么想也想不起来如何处理 每次遇到野怪times+1如何处理;后来看到了prority_queue
还有vis[x][y]不仅仅可以为0或者1还可以记录到达(x,y)点处的最小时间,后果断AC;
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
#define N 59
char map[N][N];
int vis[N][N];
int n,m,tox,toy,beginx,beginy;
int x0[] = {0,0,-1,1};
int y0[] = {1,-1,0,0};
struct Node{
int times,x,y;
Node(){}
Node(int _x,int _y,int _t){
x =_x; y = _y; times = _t;
}
friend bool operator <(Node n1,Node n2){
return n1.times > n2.times;
}
};
priority_queue<Node> q;
void BFS(int &ans) {
while(!q.empty()) q.pop();
q.push(Node(beginx,beginy,0));
map[beginx][beginy] = ‘E’;
vis[beginx][beginy] = 0;
while(!q.empty()){
Node cur = q.top(); q.pop();
if(cur.x==tox&&cur.y==toy){
ans = cur.times;
return;
}
for(int i = 0;i<4;i++){
Node tem = Node(cur.x+x0[i],cur.y+y0[i],cur.times+1);
if(tem.x>n||tem.x<=0||tem.y<0||tem.y>=n) continue;
if(map[tem.x][tem.y]==’X’) continue;
else if(map[tem.x][tem.y]==’E’&&vis[tem.x][tem.y]>tem.times){
vis[tem.x][tem.y] = tem.times;
q.push(tem);
}
else if(map[tem.x][tem.y]==’T’&&vis[tem.x][tem.y]>tem.times+1){
vis[tem.x][tem.y] = tem.times + 1;
tem.times += 1;
q.push(tem);
}
else if(map[tem.x][tem.y]==’A’){
vis[tem.x][tem.y] = tem.times;
q.push(tem);
}
}
}
ans = -1;
}
void init(){
memset(vis,0x0f0f0f0f,sizeof(vis));
}
void getData(){
for(int i = 1;i<=n;i++){
scanf(“%s”,map[i]);
for(int j = 0;j<m;j++){
if(map[i][j]==’A’){
tox = i;
toy = j;
}
else if(map[i][j]==’C’){
beginx = i;
beginy = j;
}
}
}
}
int main(){
//freopen(“Test.txt”,”r”,stdin);
while(~scanf(“%d%d”,&n,&m)){
init();
getData();
int ans = -1;
BFS(ans);
if(ans==-1) printf(“Game Over!\n”);
else printf(“%d\n”,ans);
}
return 0;
}