POJ 3984 迷宮問題

2021-07-23 22:59:14 字數 1148 閱讀 6826

description

定義乙個二維陣列: 

int maze[5][5] = ;

它表示乙個迷宮,其中的1表示牆壁,0表示可以走的路,只能橫著走或豎著走,不能斜著走,要求程式設計序找出從左上角到右下角的最短路線。

input

乙個5 × 5的二維陣列,表示乙個迷宮。資料保證有唯一解。

output

左上角到右下角的最短路徑,格式如樣例所示。

sample input

0 1 0 0 0

0 1 0 1 0

0 0 0 0 0

0 1 1 1 0

0 0 0 1 0

sample output

(0, 0)

(1, 0)

(2, 0)

(2, 1)

(2, 2)

(2, 3)

(2, 4)

(3, 4)

(4, 4)

#include #include using namespace std;

char maze[5][5];

int d[5][5]=;

int dx[4]=,dy[4]=;

int sx,sy,gx,gy;

int inf=99999999;

typedef pairp;

queueque;

void dfsn(int ,int , int);

struct zuobiao

aa[50];

int main()

sx = 0; sy = 0;//起點

gx = 4; gy = 4;//終點

//初始化佇列,先把起點座標加入到佇列中

que.push(p(sx, sy));

d[sx][sy] = 0;

//bfs

while (que.size())

} }

//得到最短路勁座標座標,用 dfs從終點一直追溯回起點得到路徑座標

dfsn(gx,gy,d[gx][gy]);

//顯示結果

for (i=1;i<=d[gx][gy];i++)

cout<<"("<1)

}}}

POJ3984 迷宮問題

題目 迷宮問題 time limit 1000ms memory limit 65536k total submissions 3183 accepted 1861 description 定義乙個二維陣列 int maze 5 5 它表示乙個迷宮,其中的1表示牆壁,0表示可以走的路,只能橫著走或豎...

POJ 3984 迷宮問題

一道比較簡單的bfs題 include include include include define max 6 using namespace std int map max max px max max py max max int movex 4 movey 4 bool vis max ma...

POJ 3984 迷宮問題

迷宮問題 time limit 1000ms memory limit 65536k total submissions 7047 accepted 4123 description 定義乙個二維陣列 int maze 5 5 它表示乙個迷宮,其中的1表示牆壁,0表示可以走的路,只能橫著走或豎著走,...