标签:
【模板】BFS
1 #include <stdio.h> 2 #include <string.h> 3 #include <queue> 4 using namespace std; 5 6 struct node 7 { 8 int x,y,step; 9 }; 10 11 char map[105][105]; 12 int vis[105][105]; 13 int to[4][2]= {1,0,-1,0,0,1,0,-1}; 14 int n,m,sx,sy,ex,ey,ans; 15 16 int check(int x,int y) 17 { 18 if(x<0 || x>=n || y<0 || y>=m) 19 return 1; 20 if(vis[x][y] || map[x][y]==‘#‘) 21 return 1; 22 return 0; 23 } 24 25 void bfs() 26 { 27 int i; 28 queue<node> Q; 29 node a,next; 30 a.x = sx; 31 a.y = sy; 32 a.step = 0; 33 vis[a.x][a.y]=1; 34 Q.push(a); 35 while(!Q.empty()) 36 { 37 a = Q.front(); 38 Q.pop(); 39 if(map[a.x][a.y]==‘E‘) 40 { 41 ans = a.step; 42 return ; 43 } 44 for(i = 0; i<4; i++) 45 { 46 next = a; 47 next.x+=to[i][0]; 48 next.y+=to[i][1]; 49 if(check(next.x,next.y)) 50 continue; 51 next.step=a.step+1; 52 vis[next.x][next.y] = 1; 53 Q.push(next); 54 } 55 } 56 ans = -1; 57 } 58 59 int main() 60 { 61 int t; 62 scanf("%d",&t); 63 while(t--) 64 { 65 scanf("%d%d",&n,&m); 66 int i,j; 67 for(i = 0; i<n; i++) 68 scanf("%s",map[i]); 69 for(i = 0; i<n; i++) 70 { 71 for(j = 0; j<m; j++) 72 { 73 if(map[i][j]==‘S‘) 74 { 75 sx = i; 76 sy = j; 77 } 78 } 79 } 80 memset(vis,0,sizeof(vis)); 81 bfs(); 82 printf("%d\n",ans); 83 } 84 85 return 0; 86 }
标签:
原文地址:http://www.cnblogs.com/jeff-wgc/p/4472930.html