BFS迷宮搜索路徑

  1 #include<graphics.h>
  2 #include<stdlib.h>
  3 #include<conio.h>
  4 #include<time.h>
  5 #include<vector>
  6 #include<queue> 
  7 #include<stack> 
  8 #include<iostream>
  9 #include <algorithm>
 10 
 11 using namespace std;
 12 
 13 struct point{ 
 14     //橫座標縱座標 
 15     int x; 
 16     int y; 
 17 }; 
 18 int **Maze;     //初始化迷宮 
 19 point **Pre;    //保存任意點在路徑中的前一步 
 20 point move[8]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1}}; //移動方向,橫豎斜均可以,八個方向 
 21 char s1[]="YES";
 22 char s2[]="NO";
 23 
 24 void create_line(int row ,int  column)//劃線
 25 {
 26   int x, y;  // 畫格子
 27    for (x=0; x<=10*(row+2); x+=10)
 28         for (y=0; y<=10*(column+2); y+=10)
 29         {
 30             line(x, 0, x, 10*(column+2));
 31             line(0, y,10*(row+2), y);
 32         }
 33 }
 34 
 35 
 36 void CreateTable(int row,int column)//初始化建立迷宮障礙區
 37 {
 38     int i,j;
 39     srand((unsigned int)time(NULL));
 40     for(i=0; i<row+2; i++)//建立迷宮,注意到用0表示可走,1表示牆,將整個輸入的迷宮再用牆圍着,處理的時候就不用特別注意邊界問題 
 41     {
 42         Maze[i][0] = Maze[i][column+1] = 1; 
 43     }
 44     for(j=0; j<column+2; j++) 
 45     {
 46         Maze[0][j] = Maze[row+1][j] = 1;       
 47     }
 48 
 49     for(i=1;i<=row;i++)
 50      for(j=1;j<=column;j++)
 51         {
 52              Maze[i][j]=rand()%2;
 53         }
 54 
 55    for(i=1;i<=row;i++)
 56      for(j=1;j<=column;j++)
 57         {
 58              if(Maze[i][j]==1)
 59             Maze[i][j]=rand()%2;
 60         }
 61 
 62     for(i=0;i<=row+1;i++)
 63      for(j=0;j<=column+1;j++)
 64      {
 65          if(Maze[i][j]==1)
 66         {
 67          setfillcolor(WHITE);
 68          fillrectangle(10*j,(10+10*i),(10+10*j),10*i);
 69         }
 70      }
 71 }
 72 
 73 bool MazePath(int row,int column,int x,int y){ 
 74     //判斷是否有路徑從入口到出口,保存該路徑(隊列) 
 75     if(x == row && y == column)return true; 
 76     queue<point> q;     //用於廣度優先搜索 
 77     point now;          //當前位置 
 78     now.x = x; 
 79     now.y = y; 
 80     q.push(now); 
 81     Maze[now.x][now.y] = -1; 
 82     while(!q.empty()){ 
 83         now = q.front(); 
 84         q.pop(); 
 85         for(int i=0; i<8; i++){ 
 86             if(now.x + move[i].x == row && now.y + move[i].y == column){ 
 87                 Maze[now.x + move[i].x][now.y + move[i].y] = -1; 
 88                 Pre[row][column] = now; 
 89                 return true; 
 90             } 
 91             if(Maze[now.x + move[i].x][now.y + move[i].y] == 0){ 
 92                 point temp;     //下個位置 
 93                 temp.x = now.x + move[i].x; 
 94                 temp.y = now.y + move[i].y; 
 95                 q.push(temp); 
 96                 Maze[temp.x][temp.y] = -1; 
 97                 Pre[temp.x][temp.y] = now; 
 98 
 99             } 
100         } 
101     } 
102     return false; 
103 } 
104 
105 
106 void PrintPath(int row,int column){ 
107     //輸出最短路徑 
108     point temp;         //保存位置 
109     stack<point> s;     //保存路徑序列 
110     temp.x = row; 
111     temp.y = column; 
112     while(temp.x != 1 || temp.y != 1){ 
113         s.push(temp); 
114         temp = Pre[temp.x][temp.y]; 
115     } 
116        setfillcolor(YELLOW);
117        fillrectangle(10*1,(10+10*1),(10+10*1),10*1);
118     while(!s.empty()){ 
119         temp = s.top(); 
120         setfillcolor(YELLOW);
121         fillrectangle(10*temp.y,(10+10*temp.x),(10+10*temp.y),10*temp.x);
122         s.pop(); 
123     } 
124     cout<<endl; 
125 }
126 
127 void result(int row,int column)
128 {
129   if(MazePath(row,column,1,1))
130   { 
131             //outtextxy(320,320,s1);
132             PrintPath(row,column); 
133   } 
134         else outtextxy(320,320,s2);
135 }
136 
137 void Init(int row,int column)
138 {
139  Maze = new int*[row + 2]; 
140  Pre = new point*[row + 2]; 
141  for(int i=0; i<row+2; i++)
142  { 
143  Maze[i] = new int[column + 2]; 
144  Pre[i] = new point[column + 2]; 
145  }
146 }
147 
148 void main()
149 {
150 int row,column;
151 cin>>row>>column;
152 Init(row,column);
153 initgraph(640,640);
154 BeginBatchDraw();
155 setlinecolor(GREEN);//設置字體顏色
156 create_line(column,row);
157 CreateTable(row,column);
158 result(row,column);
159 FlushBatchDraw();
160 EndBatchDraw();
161 getch();
162 closegraph();
163 }

相關文章
相關標籤/搜索