激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java 實現迷宮回溯算法示例詳解

java 實現迷宮回溯算法示例詳解

2020-07-31 14:51Lzfa Java教程

這篇文章主要介紹了java 實現迷宮回溯算法示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

用一個7 x 7的矩形表示迷宮,0和1分別表示的是通路和障礙。通過設計編寫程序找到藍色小球達到藍色旗子的路線

java 實現迷宮回溯算法示例詳解

思路:

構建一個迷宮(用二維數組)實現找通路的方法findRoad()
構建二維數組不難,我們主要是要實現findRoad()這個方法,在實現這個方法前,我們需要約定好一下幾個點:小球的位置當作入口(1,1),小旗的位置當作出口(5,5)數組里數的含義分別為(0沒有走過)、(1障礙)、(2走過且為正確的路線)、(3走過且為錯誤的路線)將我們每一步的走法稱為策略:下 -> 右 -> 上 ->左

實現

首先構建出迷宮

java" id="highlighter_632885">
?
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
public static void main(String[] args) {
    //1.創建二維數組模擬迷宮
    int[][] maze = new int[7][7];
    //2.初始化迷宮
    for (int i = 0; i < maze.length; i++) {
      //maze[i][j]:i控制行 j:控制列
      maze[0][i] = 1;//第1行都為1
      maze[6][i] = 1;//最后一行都為1
      maze[i][0] = 1;//第一列都為1
      maze[i][6] = 1;//最后一列都為1
      //其他位置的1
      maze[4][1] = 1;
      maze[4][2] = 1;
      maze[4][3] = 1;
      maze[4][4] = 1;
      maze[3][4] = 1;
      maze[2][3] = 1;
    }
    //打印迷宮
    System.out.println("完成迷宮初始化:");
    for (int i = 0; i < maze.length; i++) {
      for (int j = 0; j < maze[i].length; j++) {
        System.out.print(maze[i][j] + " ");
      }
      System.out.println();
    }
  }

然后寫findRoad()方法

?
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
* 使用遞歸回溯找通路  (55為出口)
 * @param maze 迷宮
 * @param i  從哪個位置開始找
 * @param j  從哪個位置開始找
 * @return 找到通路返回true 否則false
 */
public static boolean findRoad(int[][] maze, int i, int j) {
  //策略:下 -> 右 -> 上 ->左
  //0:沒有走過 1:障礙 2:走過且為正確的路線 3:走過且為錯誤的路線
  if (maze[5][5] == 2) {//找到通路
    return true;
  } else {
    if (maze[i][j] == 0) {
      //當前點沒走過,按策略走
      maze[i][j] = 2;//當前點改為2,假定能走通
      if (findRoad(maze, i + 1, j)) {//向下走
        return true;
      } else if (findRoad(maze, i, j + 1)) {//向右走
        return true;
      } else if (findRoad(maze, i - 1, j)) {//向上走
        return true;
      } else if (findRoad(maze, i, j - 1)) {//向左走
        return true;
      } else {
        //該點無法走通
        maze[i][j] = 3;
        return false;//返回到上個方法(即返回到上個點)
      }
    } else {
      //該點為 1或2或3,無法走通,直接返回上個方法(即上個點)
      return false;
    }
  }
}

main方法調用findRoad()方法,傳入創建好的迷宮,和入口點(1,1)

?
1
2
3
4
5
6
7
8
9
10
//mian方法中調用findRoad()方法
    findRoad(maze,1,1);
    //打印迷宮
    System.out.println("完成路線的迷宮:");
    for (int i = 0; i < maze.length; i++) {
      for (int j = 0; j < maze[i].length; j++) {
        System.out.print(maze[i][j] + " ");
      }
      System.out.println();
    }

效果

java 實現迷宮回溯算法示例詳解

到此這篇關于java 實現迷宮回溯算法示例詳解的文章就介紹到這了,更多相關java 實現迷宮回溯算法內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_47254987/article/details/107666338

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 一级大片视频 | 亚洲自拍第二页 | omofun 动漫在线观看 | 成年性羞羞视频免费观看 | 久久亚洲一区二区三区成人国产 | 日韩在线观看视频免费 | 日本不卡二区 | 国产一区二区影视 | 97se亚洲综合在线韩国专区福利 | 91福利社在线| 成人免费网站在线观看视频 | 国产精品99久久久久久大便 | 神马久久精品综合 | 黄色免费在线网站 | 毛片免费看网站 | 操你视频 | 成人免费看视频 | 法国性xxx精品hd专区 | 久久久久久久久久亚洲精品 | 国产91成人| 91美女福利视频 | 亚洲精品欧美一区二区三区 | 成人做爰s片免费看网站 | 久久精品无码一区二区三区 | www.777含羞草| 色妹子久久 | 日本高清一级片 | 黄色大片在线观看 | 亚洲天堂成人在线 | 亚洲五码在线观看视频 | 免费在线观看午夜视频 | 中文字幕亚洲情99在线 | av不卡毛片 | 色视频在线播放 | 一本色道久久99精品综合蜜臀 | 免费看成年人视频在线 | 黄色成人av在线 | 日日鲁夜夜视频热线播放 | 久久精品中文字幕一区二区 | 黄色特级 | 精品一区二区三区在线播放 |