12--递归【迷宫问题】
2022/9/8 23:53:07
本文主要是介绍12--递归【迷宫问题】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1 //递归 --> 迷宫问题
2 public class MazeQuestion { 3 4 public static void main(String[] args) { 5 //二维数组 6 int[][] migong = new int[8][7]; 7 //用 1 来表示墙壁 8 //先将上下左右作用初始化为1 9 for (int i = 0; i < 8; i++) { 10 for(int j = 0; j < 7; j++) { 11 migong[0][j] = 1; //上 12 migong[7][j] = 1; //下 13 migong[i][0] = 1; //左 14 migong[i][6] = 1; //右 15 } 16 } 17 //设置障碍 18 migong[3][1] = 1; 19 migong[3][2] = 1; 20 System.out.println("输出地图 --> "); 21 showMap(migong); 22 23 setWay(migong, 1, 1); 24 25 System.out.println("路径图:"); 26 showMap(migong); 27 } 28 29 public static void showMap(int[][] migong) { 30 for(int i = 0; i < 8; i++) { 31 for(int j = 0; j < 7; j++) { 32 System.out.print(migong[i][j] + " "); 33 } 34 System.out.println(); 35 } 36 } 37 38 //从migong[1][1] --> migong[6][5]; 39 //设置路径 40 //1:表示墙壁、 2:表示通路 3:表示此路不通 41 /** 42 * @param migong 要走的地图 43 * @param i 从第(i+1)行开始走 44 * @param j 从第(j+1)列开始 45 * 按照下右上左的顺序走 46 */ 47 public static boolean setWay(int[][] migong, int i, int j) { 48 if (migong[6][5] == 2) { 49 return true; 50 }else { 51 if (migong[i][j] == 0) { 52 migong[i][j] = 2; 53 if (setWay(migong, i+1, j)) { //下 54 return true; 55 }else if(setWay(migong, i, j+1)){ //右 56 return true; 57 }else if (setWay(migong, i-1, j)) { //上 58 return true; 59 }else if(setWay(migong, i, j-1)) { //左 60 return true; 61 }else { //说明该点是死路,即没有到达终点的路径 62 migong[i][j] = 3; 63 return false; 64 } 65 }else { 66 return false; 67 } 68 } 69 } 70 71 }
这篇关于12--递归【迷宫问题】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-13TiDB + ES:转转业财系统亿级数据存储优化实践
- 2024-05-09“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”实战课程已上线
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?
- 2024-05-09这种运行结果里的10.100000001,怎么能最快改成10.1?
- 2024-05-09企业src漏洞挖掘-有意思的命令执行