PTA-7-51 迷宮尋路 (20分)DFS

題目

給定一個M行N列的迷宮圖,其中 "0"表示可通路,"1"表示障礙物,無法通行。在迷宮中只允許在水平或上下四個方向的通路上行走,走過的位置不能重複走。

5行8列的迷宮如下:

0 1 1 1 0 0 0 0
0 0 0 1 0 0 0 0
0 1 0 0 0 1 0 0
0 1 1 1 0 1 1 0
1 0 0 0 0 0 0 0

則從左上角(1,1)至右下角(5,8)的最短路徑爲:

1,1–》2,1–》2,2–》2,3–》3,3–》3,4–》3,5–》4,5–》5,5–》5,6–》5,7–》5,8

題目保證每個迷宮最多隻有一條最短路徑。

請輸出該條最短路徑,如果不存在任何通路,則輸出"NO FOUND".

輸入格式:

第一行,輸入M和N值,表示迷宮行數和列數。

接着輸入M行數值,其中,0表示通路,1表示障礙物。每列數值用空格符間隔。

接下來可能輸入多組迷宮數據。

當輸入M的值爲-1時結束輸入。

輸出格式:

按行順序輸出路徑的每個位置的行數和列數,如 x,y
如果不存在任何路徑,則輸出"NO FOUND".
每組迷宮尋路結果用換行符間隔。

輸入樣例:

8 8	
0 0 1 0 0 0 1 0
0 0 1 0 0 0 1 0
0 0 0 0 1 1 0 0
0 1 1 1 0 0 0 0
0 0 0 1 0 0 0 0
0 1 0 0 0 1 0 0
0 1 1 1 0 1 1 0
1 0 0 0 0 0 0 0
4 4	
0 0 1 0
0 0 0 0
0 0 1 1 
0 1 0 0
-1 -1

輸出樣例

1,1
2,1
3,1
4,1
5,1
5,2
5,3
6,3
6,4
6,5
7,5
8,5
8,6
8,7
8,8

NO FOUND

代碼:

#include<bits/stdc++.h>
using namespace std;
int n,m,flag=0,Min;
int Map[100][100];
int vis[100][100];
int dir[4][2]={0,1,0,-1,-1,0,1,0};
int stepA[100][2];//記錄當前路徑
int stepB[100][2];//記錄最短路徑 
void dfs(int x,int y,int step){
	if(step>Min){
		return;
	}
	if(x==n&&y==m){
		for(int i=0;i<100;i++){
			if(stepA[i][0]==-1&&stepA[i][1]==-1){
				break;
			}
			stepB[i][0]=stepA[i][0];
			stepB[i][1]=stepA[i][1];
		}
		Min=step;
		return;
	}
	for(int i=0;i<4;i++){
		int xx=x+dir[i][0];
		int yy=y+dir[i][1];
		if(xx<=0||yy<=0||xx>n||yy>m){
			continue;
		}
		if(!vis[xx][yy]&&Map[xx][yy]==0){
			stepA[step][0]=xx;
			stepA[step][1]=yy;
			
			vis[xx][yy]=1;
			dfs(xx,yy,step+1);
			vis[xx][yy]=0;
		}
	}
	return;
}
int main(){
	while(scanf("%d %d",&n,&m)&&m!=-1){
		for(int i=1;i<=n;i++){
			for(int j=1;j<=m;j++){
				scanf("%d",&Map[i][j]);
			}
		}
		memset(vis,0,sizeof(vis));
		memset(stepA,-1,sizeof(stepA));
		memset(stepB,-1,sizeof(stepB));
		vis[1][1]=1;
		Min=10000;
		dfs(1,1,0);
		if(Min==10000){
			printf("NO FOUND\n");
		}
		else{
			printf("1,1\n");
			for(int i=0;i<Min;i++){
				printf("%d,%d\n",stepB[i][0],stepB[i][1]);
			}
			printf("\n");
		}
	}
	return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章