hanoi塔问题如下图所示_hanoi塔问题最经典的算法

hanoi塔问题如下图所示_hanoi塔问题最经典的算法什么是hanoi塔?汉诺塔问题:古代有一个梵塔,塔内有三个座A、B、C,A座上有64个盘子,盘子大小不等,大的在下,小的在上。有一个和尚想把这64个盘子从A座移到B座,但每次只能允许移动一个盘子,并且在移动过程中,3个座上的盘子始终保持大盘在下,小盘在上。如下图问题解答问题定义我们把左边的柱子叫做A,中间的柱子叫做B,右边的柱子叫做Chanoi塔的搬运过程;i

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

什么是hanoi塔?

汉诺塔问题:古代有一个梵塔,塔内有三个座A、B、C,A座上有64个盘子,盘子大小不等,大的在下,小的在上。有一个和尚想把这64个盘子从A座移到B座,但每次只能允许移动一个盘子,并且在移动过程中,3个座上的盘子始终保持大盘在下,小盘在上。如下图

hanoi塔图示

问题解答

问题定义
我们把左边的柱子叫做A,中间的柱子叫做B,右边的柱子叫做C

hanoi`塔的搬运过程;
i :左边的柱子只有两个圆盘

我们先假设在A柱子上只有两个圆盘,不用图我们用大脑想象出来最佳流程就是,现在最小的放在B柱子上面然后把大的放在C上面,最后把B柱子上面的小圆盘放在C柱子上。

ii:左边的柱子上面有三个圆盘 过程如下图: `在这种情况下,我们可以把上面的两个圆盘看作是一个,然后又回到了i情况,下图展示了三个圆盘的转移过程` ![三个圆盘的hanoi过程](https://img-blog.csdnimg.cn/img_convert/f8d12ace981cf0cd72af4da2f57daaf1.png) iii:左边的柱子上有四个圆盘的时候 在这种情况我们通过作图做出hanoi的转移流程是很困难的了,我们可以用在`ii`中提及到的过程,就是我们先把上面的三个看作是一个,我们第一步的目的就是把前三个移动到中间的柱子上去。下面简单说一下转移步骤 1. 将A柱子上面的三个移动到B柱子上面(借助C柱子) 2. 将A柱子上面中最下面的圆盘移动到C柱子上面 3. 将B柱子上面的所有圆盘移动到C柱子上面(借助A柱子) 过程如下图: ![四个圆盘的hanoi](https://img-blog.csdnimg.cn/img_convert/7e80f4dd8a45878f9ae993e6a0fa6ea8.png) > 问题总结 > 通过上面的描述我们把hanoi移动的步骤一般化 >


  1. 将左边柱子上的N-1个圆盘移动带中间的柱子上
  2. 将第N个圆盘移动到最右边的柱子
  3. 将中间柱子上的所有圆盘移动到最右边的柱子

下面我们给出具体的代码

void hanoi(int n,char A,char B,char C)
{
    if(n<=1) {
        printf("1 move %c to %c\n",A,C);
        return ;
    }
    hanoi(n-1,A,C,B);
    printf("%d move %c to %c \n",n,A,C);
    hanoi(n-1,B,A,C);
}

Jetbrains全家桶1年46,售后保障稳定

不要在看了,这就是全部代码了。已经没有了
╭︿︿︿╮
{/ o o /}
( (oo) )
︶ ︶︶
以上是对hanoi塔的总体概述,下面就要聊一聊真正的代码流程!

代码详解

hanoi(n,A,B,C)代表的意义就是讲n个圆盘从A移动到C借助B;

  • n等于1的时候,就代表把当前A中最大的圆盘直接从A移动到C
  • n等于2的时候,就调用hanoi(2,A,B,C)也就是执行下面的三个步骤下面就是本文中重点了
  1. 调用honoi(1,A,C,B)就是相当于把***B柱和C柱交换***了
  2. 执行打印语句,不进行继续调用。所以不用交换柱子
  3. 调用hanoi(1,B,A,C)相当于把***B柱和A柱交换***了
    上面的语句可以表述为:
hanoi(1,A,C,B); 
printf("%d move %c to %c \n",n,A,C);
hanoi(1,B,A,C); 

这就是对代码的解释!
当圆盘更多的时候无非就是进行递归知道递归到上面的状态,比如有三个圆盘的时候,调用的是:

hanoi(2,A,C,B); //step1
printf("%d move %c to %c \n",n,A,C);
hanoi(2,B,A,C); 

只要理解了前两个对后面的理解也就不难了!还有一点题外话,当递归到程序注释的step1的时候,会为后续语句分配空间但不执行

hanoi塔还有一个进阶的题目就是判断当前的状态时第几个最优的状态,将在下篇文章进行讲述!

如果对我的文章感兴趣可以关注的公众号:云影原生。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/210738.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月25日 下午1:43
下一篇 2025年7月25日 下午2:15


相关推荐

  • 批处理系统和分时系统的区别

    批处理系统和分时系统的区别要弄清批处理系统和分时系统的区别 首先我们得了解何为批处理系统和分时系统

    2026年3月19日
    2
  • vmware10.0密钥_windows10永久激活密钥

    vmware10.0密钥_windows10永久激活密钥VMwareWorkstation是功能最强大的热门虚拟机软件,现已自带原生简体中文。用户可在在虚拟机同时运行各种操作系统,进行开发、测试、演示和部署软件,虚拟机中复制服务器、台式机和平板环境,每个虚拟机可分配多个处理器核心、千兆字节的主内存和显存。VMwareWorkstation™11延续了VMware的传统,即提供技术专业人员每天在使用虚拟机时所依赖的领先功能和性能。借

    2025年11月16日
    3
  • 如何理解掩码、反掩码、通配符「建议收藏」

    如何理解掩码、反掩码、通配符「建议收藏」反掩码、掩码和通配符的区别一、掩码在掩码中,1表示精确匹配,0表示随机1和0,永远不交叉;1永远在左边,0永远在右边;在配置IP地址以及路由的时候,会使用掩码;二、反掩码在反掩码中,1表示随机,0表示精确匹配0和1,永远不交叉;0永远在左边,1永远在右边;在路由协议的配置中,通过network命令进行网段宣告时,会使用三、通配符在统配符中,1表示随机,0表示精确匹配0和1的位置,没有任何的固定限制可以连续,可以交叉在ACL中,使用的通配符通配符掩码表CIDR子网掩码反掩

    2022年7月19日
    18
  • linux查看端口占用的命令_端口占用查看命令

    linux查看端口占用的命令_端口占用查看命令在Linux使用过程中,需要了解当前系统开放了哪些端口,并且要查看开放这些端口的具体进程和用户,可以通过netstat命令进行简单查询netstat命令各个参数说明如下:  -t:指明显示TCP端口  -u:指明显示UDP端口  -l:仅显示监听套接字(所谓套接字就是使应用程序能够读写与收发通讯协议(protocol)与资料的程序)  -p:显示进程标识符和程序

    2022年7月27日
    7
  • resttemplate post请求发送body_java发送post请求

    resttemplate post请求发送body_java发送post请求当使用RestTemplate进行http请求时,的确很方便,但是当需要进行post请求时遇到了坑1POST传递参数:采用LinkedMultiValueMap,不能使用HashMapStringurl=’http://posturl’;MultiValueMap<String,String>map=newLinkedMultiValueMap&lt……

    2025年8月31日
    7
  • Autoware学习笔记waypoint_follower之pure_pursuit

    Autoware学习笔记waypoint_follower之pure_pursuit1 pure pursuit 的 launch 文件如下 launch argname is linear interpolatio default True argname publishes for steering robot default False launch

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号