Java數據結構 遞歸之迷宮回溯案例講解
問題介紹:
用二維數組表示一個迷宮,設置迷宮起點和終點,輸出迷宮中的一條通路
實現思路:
二維數組表示迷宮:

0表示路且未走過、1表示墻、2表示通路,3表示已經走過但走不通
設置尋路方法setWay,傳入地圖和坐標參數
默認方向策略:下、右、上、左
假定傳入的店沒有走過且可以走通,將其值置為2,然后向下尋路,也就是將坐標 (i + 1, j) 傳入尋路方法中
進行遞歸尋路,向下移動后,再次按照方向策略進行尋路,即再向下尋路,直到遇到死路,即下右左均走不通(因為將走過的路置為2,故向上也走不通,即遇到死路時回頭不算通路),則將該點置為3,并返回false,回到上一個遞歸,找尋方向策略中剩下的方向,實現回溯
代碼實現:
public class Maze {
public static void main(String[] args) {
maze();
}
//迷宮回溯問題
public static void maze() {
//創(chuàng)建二維數組模擬迷宮
//使用1表示墻,0表示路
int[][] map = new int[][]{
{1, 1, 1, 1, 1, 1, 1},
{1, 0, 0, 0, 0, 0, 1},
{1, 0, 1, 0, 0, 0, 1},
{1, 0, 1, 0, 1, 1, 1},
{1, 1, 0, 0, 0, 0, 1},
{1, 0, 1, 1, 0, 1, 1},
{1, 0, 0, 0, 0, 0, 1},
{1, 1, 1, 1, 1, 1, 1}
};
//輸出地圖
System.out.println("迷宮:");
for (int[] row : map) {
for (int i : row) {
System.out.printf("%d\t", i);
}
System.out.println();
}
System.out.println("尋路結果:");
//開始尋路
setWay(map, 1, 1);
//輸出地圖
for (int[] row : map) {
for (int i : row) {
System.out.printf("%d\t", i);
}
System.out.println("");
}
}
//傳入地圖map
//傳入開始位置(i, j)
//如果能到達右下角(6, 5),則說明找到通路
//0表示未走過,1表示墻,2表示可以走的通路,3表示已經走過,但是走不通
//確定方向策略:下 -> 右 -> 上 -> 左
//若該點走不通,則回溯
public static boolean setWay(int[][] map, int i, int j) {
if (map[6][5] == 2) {
//通路已經找到
return true;
} else {
if (map[i][j] == 0) {
//如果當前點沒有走過
map[i][j] = 2; //假定該點可以走通
if (setWay(map, i + 1, j)) {
//向下走
return true;
} else if (setWay(map, i, j + 1)) {
//向右走
return true;
} else if (setWay(map, i - 1, j)) {
//向上走
return true;
} else if (setWay(map, i, j - 1)) {
//向左走
return true;
} else {
//該點走不通
map[i][j] = 3;
return false;
}
} else {
//如果map[i][j] != 0
//可能是1、2、3
return false;
}
}
}
}
輸出結果:
迷宮: 1 1 1 1 1 1 1 1 0 0 0 0 0 1 1 0 1 0 0 0 1 1 0 1 0 1 1 1 1 1 0 0 0 0 1 1 0 1 1 0 1 1 1 0 0 0 0 0 1 1 1 1 1 1 1 1 尋路結果: 1 1 1 1 1 1 1 1 2 2 2 0 0 1 1 3 1 2 0 0 1 1 3 1 2 1 1 1 1 1 0 2 2 0 1 1 0 1 1 2 1 1 1 0 0 0 2 2 1 1 1 1 1 1 1 1
到此這篇關于Java數據結構之遞歸之迷宮回溯案例講解的文章就介紹到這了,更多相關Java數據結構之遞歸之迷宮回溯內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
springboot項目數據庫配置類DatabaseConfig示例詳解
這篇文章主要介紹了springboot項目數據庫配置類DatabaseConfig實現代碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08
springboot項目如何在linux服務器上啟動、停止腳本
這篇文章主要介紹了springboot項目如何在linux服務器上啟動、停止腳本問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
使用jquery 的ajax 與 Java servlet的交互代碼實例
這篇文章主要介紹了使用jquery 的ajax 與 Java servlet的交互代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-09-09
MyEclipse 2016 CI 4新增BootStrap模板
MyEclipse2016是一款全球使用最為廣泛的企業(yè)級開發(fā)環(huán)境程序,這篇文章主要介紹了MyEclipse 2016 CI 4新增BootStrap模板的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-06-06

