NYOJ82迷宮尋寶 一

2021-06-27 06:46:38 字數 1625 閱讀 9005

時間限制:

1000 ms  |  記憶體限制:

65535 kb

難度:4 描述

乙個叫acm的尋寶者找到了乙個藏寶圖,它根據藏寶圖找到了乙個迷宮,這是乙個很特別的迷宮,迷宮裡有n個編過號的門(n<=5),它們分別被編號為a,b,c,d,e.為了找到寶藏,acm必須開啟門,但是,開門之前必須在迷宮裡找到這個開啟這個門所需的所有鑰匙(每個門都至少有一把鑰匙),例如:現在a門有三把鑰匙,acm就必須找全三把鑰匙才能開啟a門。現在請你編寫乙個程式來告訴acm,他能不能順利的得到寶藏。

輸入

輸入可能會有多組測試資料(不超過10組)。

每組測試資料的第一行包含了兩個整數m,n(1

輸出每行輸出乙個yes表示acm能找到寶藏,輸出no表示acm找不到寶藏。

樣例輸入

4 4 

s.x.

a.x.

..xg

....

3 4

s.xa

.axb

b.ag

0 0

樣例輸出

yes 

no

這題跟普通廣搜多的一點區別就是,這裡多了乙個計數,其他的跟普通廣搜差不多

#include #include #include #include using namespace std;

struct node

;int m, n, sx, sy, key[10];

char maze[25][25];

int di[4][2] = , , , };

queue q;

int bfs()

; q.push(no);

maze[sx][sy] = 'x';

int i, nx, ny;

while(!q.empty())

if(maze[nx][ny] == '.')

;q.push(de);

maze[nx][ny] = 'x';

}if(maze[nx][ny] >= 'a' && maze[nx][ny] <= 'e')

;q.push(de);

maze[nx][ny] = 'x';

}if(maze[nx][ny] >= 'a' && maze[nx][ny] <= 'e')

;q.push(de);

maze[nx][ny] = 'x';

}else}}

}}

return -1;

}int main()

if(maze[i][j] >= 'a' && maze[i][j] <= 'z')}}

result = bfs();

if(result == -1)

printf("no\n");

else

printf("yes\n");

memset(maze, 0, sizeof(maze));

memset(key, 0, sizeof(key));

while(!q.empty())

q.pop();

}return 0;

}

nyoj82迷宮尋寶(一)

時間限制 1000 ms 記憶體限制 65535 kb 難度 4 描述 乙個叫acm的尋寶者找到了乙個藏寶圖,它根據藏寶圖找到了乙個迷宮,這是乙個很特別的迷宮,迷宮裡有n個編過號的門 n 5 它們分別被編號為a,b,c,d,e.為了找到寶藏,acm必須開啟門,但是,開門之前必須在迷宮裡找到這個開啟這...

迷宮尋寶(一) nyoj 82

時間限制 1000 ms 記憶體限制 65535 kb 難度 4 描述 乙個叫acm的尋寶者找到了乙個藏寶圖,它根據藏寶圖找到了乙個迷宮,這是乙個很特別的迷宮,迷宮裡有n個編過號的門 n 5 它們分別被編號為a,b,c,d,e.為了找到寶藏,acm必須開啟門,但是,開門之前必須在迷宮裡找到這個開啟這...

Nyoj 82 迷宮尋寶(一)

include include include include using namespace std const int maxn 25 struct point pos point pos targetpos,doorpos 5 寶藏的位置,每個門的位置 char graph maxn maxn...