汉诺塔问题(递归超详细)C++,leetcode

文章目录


前言

在本文章中,我们将要详细介绍一下汉诺塔问题,本题目我们采用递归的方式解决相关的内容

一、题目分析

题目要求详解:

🌟 有三个柱子假设名称分别为a,b,c,其中a柱子上有若干个盘子。

🌟这些盘子按照从底往上大小依次减小的次序摆放。

🌟不论盘子在哪个柱子上都必须要求下面盘子的大小都大于上面盘子的大小

🌟将a柱子上的若干盘子通过b柱子按照要求转移到柱子上

二、算法原理

☀️ ☀️ 学过的小伙伴都知道这道题目可以用递归解决,那我们为什么要用递归算法解决,为什么不用贪心,动态规划等算法呢??

1.为什么要用递归

首先简单看一下递归:函数自己调用自己,将主问题分解为相同子问题,子问题又可以调用相同的子问题。

我们要有规律的放挪动盘子,每一步的意义是什么,同时注意不要分解的太过于细致

把每一步分析一下

🔱🔱n==1,直接可以把a柱子上的盘子放到c柱子上,不用借助b柱子就可以实现

🔱🔱n==2,题目要求我们把a柱子上的2个盘子通过b柱子转移到c柱子上。

💗💗首先我们要把a柱子上的盘子挪到c柱子上,先想办法把a柱子上最下面那个最大的盘子挪到c柱子上,剩余的那一个才可以挪过去。

💗💗要挪动a柱子上最大的盘子,得先把a柱子上那个小盘子挪走,那这个怎末挪动呢??

💗💗我们发现这一步和n== 1时的情景非常类似 。按照n==1的步骤,把那个小盘子直接挪到b柱子上。

💗💗这时我们就可以把a柱子上最大的那个盘子挪到c柱子上了。

💗💗最后把那个小盘子挪动c柱子上就可以了

🔱🔱n==3,题目要求我们把a柱子上的3个盘子通过b柱子转移到c柱子上。

💗💗首先我们要把a柱子上的盘子挪到c柱子上,先想办法把a柱子上最下面那个最大的盘子挪到c柱子上,剩余的那俩个才可以挪过去。

💗💗要挪动a柱子上最大的盘子,得先把a柱子上那两个盘子挪走,那这个怎末挪动呢??

💗💗我们发现这一步和n== 2时的情景非常类似 。按照n==2的步骤,把那俩个小盘子通过c柱子挪动到b柱子上(不能挪动到c柱子上,我们需要用这个柱子放最大盘子)。

💗💗这时我们就可以把a柱子上最大的那个盘子挪到c柱子上了。

💗💗最后把那个俩盘子通过a柱子挪动c柱子上就可以了

🔱🔱n==N,题目要求我们把a柱子上的N个盘子通过b柱子转移到c柱子上。

💗💗首先我们要把a柱子上的盘子挪到c柱子上,先想办法把a柱子上最下面那个最大的盘子挪到c柱子上,剩余的那N-1个才可以挪过去。

💗💗要挪动a柱子上最大的盘子,得先把a柱子上那N-1个盘子挪走,那这个怎末挪动呢??

💗💗我们发现这一步和n== N-1时的情景非常类似 。按照n==N-1的步骤,把那N-1个小盘子通过c柱子挪动到b柱子上(不能挪动到c柱子上,我们需要用这个柱子放最大盘子)。

💗💗这时我们就可以把a柱子上最大的那个盘子挪到c柱子上了。

💗💗最后把那N-1盘子通过a柱子挪动c柱子上就可以了

通过这里我们发现,他们采用的相同的方式实现,这与递归的定义是一致的。

递归是一种在函数定义中使用函数自身的方法。在递归过程中,函数将问题分解为更小的子问题,并通过调用自身来解决这些子问题。递归通常用于解决可以被分解为相同类型的子问题的问题,直到达到基本情况为止。

2.如何编写代码

💫 💫.重复子问题---》函数头

将a柱子上的N个盘子借助b柱子转移c柱子上(知道递归需要哪些参数)

dfs(a,b,c,n);

💫 💫.只关心某个问题---》函数体

1.先把a柱子上除去最后一个盘子通过c柱子挪到b柱子上-->dfs(a,c,b,n-1);

2.把a柱子剩余的挪动到c柱子上----》 c.push_back(a.back()); a.pop_back();

3.把b柱子上的盘子通过a柱子转移到c柱子上--》dfs(b,a,c,n-1);

💫 💫.递归出口---》到哪不可再分

我们发现仅仅剩下一个盘子就不可再分,那麽也就是n==1就是递归出口,把a柱子盘子直接放在c柱子上

n==1-->c.push_back(a.back()); a.pop_back();

三、代码实现

总结

以上就是我们对Leetcode中汉诺塔问题详细介绍,希望对大家的学习有所帮助,仅供参考 如有错误请大佬指点我会尽快去改正 欢迎大家来评论~~

相关推荐
Jul1en_8 分钟前
【算法】分治-归并类题目
java·算法·leetcode·排序算法
再__努力1点9 分钟前
【77】积分图像:快速计算矩形区域和核心逻辑
开发语言·图像处理·人工智能·python·算法·计算机视觉
Evand J17 分钟前
【2026课题推荐】基于小波/互相关/FFT的卡尔曼滤波的轨迹估计,及MATLAB例程的运行结果
开发语言·matlab·目标跟踪·轨迹跟踪
独自归家的兔24 分钟前
Java Robot 详解:系统级鼠标 / 键盘模拟的核心原理与实战
java·开发语言
小灰灰搞电子30 分钟前
Qt 开发环境选择Qt Creator、Visual Studio还是 VS Code?
开发语言·qt·visual studio
何中应31 分钟前
Bean的三种注入方式
开发语言·spring boot·后端·spring
java修仙传41 分钟前
力扣hot100:寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
胖咕噜的稞达鸭1 小时前
算法日记专题:位运算II( 只出现一次的数字I II III 面试题:消失的两个数字 比特位计数)
c++·算法·动态规划
茉莉玫瑰花茶1 小时前
ProtoBuf - 3
服务器·c++·protobuf
wanghowie1 小时前
01.03 Java基础篇|面向对象核心与设计实践
java·开发语言