时隔3天,我终于理解了四个盘子的汉诺塔问题(Java实现)

2024-03-11 01:20

本文主要是介绍时隔3天,我终于理解了四个盘子的汉诺塔问题(Java实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.汉诺塔问题

2.思路讲解

2.1 一个盘子的情况。

2.2 两个盘子的情况

2.3 三个盘子的情况

3.四个盘子的汉诺塔问题

3.1 四个盘子的思路

3.2 实现代码来解决四个盘子的汉诺塔


1.汉诺塔问题

汉诺塔是啥大家都知道,汉诺塔的故事这里就不做介绍了,有读者感兴趣的可以去搜一搜,作者是用Java来实现的汉诺塔。

编程实现把 A 的 n 个盘子移动到 C

这是一个要使用递归解决的问题

要求:

  • 每次只能移动1个盘子
  • 大盘子只能放在小盘子下面

我们的目标是要解决4个盘子的汉诺塔问题,下面是移动完成的示意图

移动前:

 移动后:

 动态演示图

2.思路讲解

2.1 一个盘子的情况。

如果是一个盘子,直接将A上的盘子移动到C即可。(一步)

 步骤:A -> C

动态演示图

2.2 两个盘子的情况

如果是两个盘子,先将A上的小盘子移动到B上;再将A上的大盘子移动到C上,最后将B上的小盘子移动到C上即可。(三步)

步骤:A -> B    A -> C   B -> C

动态演示图

2.3 三个盘子的情况

如果是三个盘子,先将A上的盘子移动到C上;再将A上的盘子移动到B上,再将C上的盘子移动到B,再将A 上的盘子移动到C,再将上B的盘子移动到A,再将B的盘子移动到C,最后将A移动到C即可。(七步)

步骤:A -> C     A -> B     C -> B     A -> C     B -> A     B - > C     A -> C

动态演示图

根据三个例子可以发现,除了只有一个盘子的情况。盘子在移动到C的过程中会有 n-1 个盘子在B上暂存。

两个盘子 n-1 就是会有一个盘子在B上暂存

三个盘子 n-1 就是会有两个个盘子在B上暂存

所以解决四个盘子的方法就是先想办法把三个的盘子暂存到B上,再把最后一个盘子直接放到C上。对于B上的三的盘子,可以借用A逐步放到C上。

3.四个盘子的汉诺塔问题

3.1 四个盘子的思路

  1. 借助C把 n-1 个盘子移动到B
  2. 把A剩下的盘子移动到C
  3. 借助A把 n-1 个盘子移动到C

3.2 实现代码来解决四个盘子的汉诺塔

    /*** @name 递归求解汉诺塔* @param start   起始位置* @param transit 中转位置* @param end     目标位置* **/public static void hanio(char start, char transit, char end, int number) {if (1 == number) {//只有一个盘子//直接将盘纸移动到Cmove(start, end);return;}else {//盘子大于1个//此时 transit 是目标位置;而 end 是中转位置hanio(start, end, transit, number - 1);//借助C将n-1个盘子移动到B上move(start, end);//此时 start 是中转位置,而end是目标位置hanio(transit, start, end, number - 1);//借助A把n-1个盘子移动到C上}}/*** @param start     起始位置* @param transit   目标位置**/public static void move(char start, char transit) {System.out.print(start +"->"+ transit + " ");}public static void main(String[] args) {hanio('A', 'B', 'C', 1);System.out.println();hanio('A', 'B', 'C', 2);System.out.println();hanio('A', 'B', 'C', 3);System.out.println();hanio('A', 'B', 'C', 4);}

代码结果:

 前三行分别是1、2、3个盘子的移动过程,对照之前的思路讲解可以发现步骤没有错误。

第四行就是四个盘子的汉诺塔所需要的步骤。(十五步)

这篇关于时隔3天,我终于理解了四个盘子的汉诺塔问题(Java实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/796134

相关文章

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

SpringSecurity JWT基于令牌的无状态认证实现

《SpringSecurityJWT基于令牌的无状态认证实现》SpringSecurity中实现基于JWT的无状态认证是一种常见的做法,本文就来介绍一下SpringSecurityJWT基于令牌的无... 目录引言一、JWT基本原理与结构二、Spring Security JWT依赖配置三、JWT令牌生成与

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

如何配置Spring Boot中的Jackson序列化

《如何配置SpringBoot中的Jackson序列化》在开发基于SpringBoot的应用程序时,Jackson是默认的JSON序列化和反序列化工具,本文将详细介绍如何在SpringBoot中配置... 目录配置Spring Boot中的Jackson序列化1. 为什么需要自定义Jackson配置?2.

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题