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() { //创建二维数组模拟迷宫 //使用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数据结构之递归之迷宫回溯内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解析使用jdbc,hibernate处理clob/blob字段的详解
本篇是对使用jdbc,hibernate处理clob/blob字段进行了详细的分析介绍,需要的朋友参考下2013-05-05file.mkdir()、file.mkdirs()和file.createNewFile()的区别
本文主要介绍了file.mkdir()、file.mkdirs()和file.createNewFile()的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-04-04Java、C++中子类对父类函数覆盖的可访问性缩小的区别介绍
这篇文章主要给大家介绍了关于Java、C++中子类对父类函数覆盖的可访问性缩小的区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2018-01-01Spring Data Jpa 中原生查询 REGEXP 的使用详解
这篇文章主要介绍了Spring Data Jpa 中原生查询 REGEXP 的使用详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-12-12
最新评论