BFS学习
BFS,广度优先搜索,也称深度优先搜索,即搜索每次可达的所有点并进行标记,直到搜索范围覆盖所需要寻找的点。下面我们从迷宫搜索来看看DFS的应用。
迷宫搜索
寻找迷宫中从起点到终点的最短可行路径。
解题思路
用二维数组记录迷宫,并标记迷宫的障碍点,再通过DFS找出最短路径。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
| #include <cstdio> struct note{ int x; int y; int f; int s; }; int next[4][2]={ {0,1},{1,0},{0,-1},{-1,0} }; int main() { struct note que[2501]; int a[51][51]={0},book[51][51]={0}; int m,n;scanf("%d%d",&m,&n); for(int i=1;i<=m;i++) for(int j=1;j<=n;j++) scanf("%d",&a[i][j]); int startX,startY,endX,endY,tx,ty; scanf("%d%d%d%d",&startX,&startY,&endX,&endY); book[startX][startY]=1; int flag=0; int head=1,tail=2; que[head].x=startX;que[head].y=startY; que[head].f=0;que[head].s=0; while(head<tail) { for(int i=0;i<4;i++){ tx=que[head].x+next[i][0]; ty=que[head].y+next[i][1]; if(tx<1||tx>m||ty<1||ty>n) continue; if(a[tx][ty]==0&&book[tx][ty]==0){ book[tx][ty]=1; que[tail].x=tx; que[tail].y=ty; que[tail].f=head; que[tail].s=que[head].s+1; tail++; } if(que[tail].x==endX&&que[tail].y==endY){ flag=1; break; } } if(flag==1) break; head++; } printf("%d\n",que[tail-1].s); }
|