Java怎么通过递归算法解决迷宫与汉诺塔及八皇后问题
1.递归的重要规则
在执行一个方法时,就创建一个新的受保护的独立空间(栈空间)。
方法的局部变量时独立的,不会相互影响。
如果方法中使用的是应用类型变量(比如数组,对象),就会共享该引用类型的数据。
递归必须向退出递归的条件逼近,否则就是无限递归。
当一个方法执行完毕,或者遇到return,就会返回,遵循谁调用,就将结果返回给谁,同时当方法执行完毕或者返回时,该方法也就执行完毕。
2.递归的三个案例
1.老鼠出迷宫
//一个7列8行的迷宫 //分析 //1.我们用一个二维数组来表示迷宫 //2.定义一个findWay方法来找路径,返回值为布尔类型, //3.若找到路则返回true,否则返回false。 //4.我们用1来表示障碍物 //5.我们初始化老鼠当前坐标(1,1) //6.用0表示能走,1表示不能走,2表示走过能走,3表示走过但走不通 //7.当map[6][5]=2时则说明找到了出迷宫的路,否则继续找路 //8.我们定义一个试探走的规则,我们假设 下->右->上->左 public class MiGong{ public static void main(String [] args){ //迷宫初始化 int [][] map = new int [8][7]; for(int i = 0; i < 7; i++){ map[0][i] = 1; map[7][i] = 1; } for(int j = 0 ; j < 8; j++){ map[j][0] = 1; map[j][6] = 1; } map[3][1]= 1; map[3][2]= 1; for (int k = 0; k < map.length; k++) { for(int m = 0; m < map[k].length; m++){ System.out.print(map[k][m] + " "); } System.out.println(); } t way = new t(); way.findWay(map, 1, 1); System.out.println("=====找到路径后的地图====="); for (int k = 0 ;k < map.length; k++) { for(int m = 0;m < map[k].length; m++){ System.out.print(map[k][m] + " "); } System.out.println(); } } } class t{ public boolean findWay(int [][] map ,int x , int y){ if(map[6][5]==2){//递归出口若终点处的值为2则表明能找到一条路 return true; }else{ if(map[x][y]==0){//首先若当前位置为0,则表明可以走 map[x][y]=2;//我们假设选这条路可以走通,将当前位置赋为2 //然后按照我们的试探规则依次试探下->右->上->左 if(findWay(map, x+1, y))//递归调用findway函数如果下可以走则返回true return true; else if (findWay(map, x, y+1))//否则还继续看右边能不能走 return true; else if(findWay(map, x-1, y))//上 return true; else if(findWay(map, x, y-1))//左 return true; else { map[x][y]=3; return false; } }else // map[x][y]=1,2,3 return false; } } }
2.汉诺塔
相传在古印度圣庙中,有一种被称为汉诺塔(Hanoi)的游戏。该游戏是在一块铜板装置上,有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺序放置n个金盘。游戏的目标:把A杆上的金盘全部移到C杆上,并仍保持原有顺序叠好。操作规则:每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下,小盘在上,操作过程中盘子可以置于A、B、C任一杆上。
分析:对于这样一个问题,任何人都不可能直接写出移动盘子的每一步,但我们可以利用下面的方法来解决。设移动盘子数为n,为了将这n个盘子从A杆移动到C杆,可以做以下三步:
(1)以C盘为中介,从A杆将1至n-1号盘移至B杆;
(2)将A杆中剩下的第n号盘移至C杆;
(3)以A杆为中介;从B杆将1至n-1号盘移至C杆。
import java.util.Scanner; public class HanoiTower{ public static void main(String []args ){ System.out.println("请输入你要移动的盘数:"); tower m = new tower(); Scanner input = new Scanner(System.in); int num = input.nextInt(); m.moveWay(num,'A','B','C'); } } class tower{ //num表示要移动的盘的个数,a,b,c分别表示a塔,b塔,c塔 public void moveWay(int num,char a,char b,char c){ if(num == 1){//如果只有一个盘,直接将其从a移动到c System.out.println(a + "->" + c); } else {//如果有多个盘将最后一个盘以上的盘看成一个整体,借助c,移动到b,然后将最后一个盘移到c moveWay(num-1, a, c, b); System.out.println(a + "->" + c); //然后再将b的所有盘,借助a,移动到c moveWay(num-1, b, a, c); } } }
3.八皇后
问题表述为:在8×8格的国际象棋上摆放8个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。
public class Queen8{ //第一个皇后先放在第一行第一列 //第二个放在第二行第一列,然后判断是否发生冲突 //如果冲突,则继续放第二列,第三列,依次直到找到不发生冲突的位置 //第三个皇后,还是按照第二个一样依次找直到第八个皇后也能放在一个不发生冲突的地方,就算找到一个可行解。 //当得到一个可行解时,回退到上一个栈开始回溯,既可以得到第一个皇后放在第一列的所有可行解 //然后回头继续第一个皇后放在第二列,重复前面的操作 //用一个一维数组来表示皇后放置的位置 //列如arry[1]=3,表示第二个皇后放在第二行第四列 int max = 8; int [] arry = new int [max]; static int count = 0; public static void main(String[]args){ Queen8 queen8 = new Queen8(); queen8.locate(0); System.out.print("摆法一共有:"+ count +"种"); } // 依次放入皇后,并判断是否冲突 public void locate(int n){ if(n == max){ display(); return; } for(int i = 0; i < max; i++){ //先把皇后n放到第一列 arry[n] = i; if(judge(n)){//不冲突则继续放置第n+1个皇后 locate(n+1); } //如果冲突则继续往后一列放置 } } public boolean judge(int n){ for(int i = 0; i < n; i++){ //arry[i]==arry[n]表示在同一列 //Math.abs(i-n)==Matn.abs(arry[i]-arry[n])表示在同一斜线 if(arry[i] == arry[n] || Math.abs(i - n) == Math.abs(arry[i] - arry[n])){ return false; } } return true; } public void display(){ count++; for(int i = 0; i < arry.length; i++){ System.out.print(arry[i]+" "); } System.out.println(); } }
以上是Java怎么通过递归算法解决迷宫与汉诺塔及八皇后问题的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip
