当前位置:网站首页>C语言学习练习题:汉诺塔(函数与递归)
C语言学习练习题:汉诺塔(函数与递归)
2022-07-30 12:33:00 【51CTO】
问题描述:
汉诺塔(Tower of Hanoi),又称河内塔,是一个源于 印度古老传说的 益智玩具。 大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令 婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
问题(图文)分析:
初始状态:以三个圆盘为例,圆盘1,2,3最初都放置在A柱上面,先要将1,2,3按照规则移动到C柱上。

移动步骤:
(1)1:A->C

(2)2:A->B

(3)1:A->B

(4)3:A->C

(5)1:B->A

(6)2:B->C

(7)1:A->C

递归思路:
首先将2和1看成是一个整体,将该整体移动到B柱(借助C柱),然后将3移动到C柱;之后将1移动到A柱(借助C柱),将2移动到C柱;最后将1移动到C柱。如图:

推导到n个圆盘:
先将1第n-1个圆盘看成是一个整体,将其通过C移动到B,然后将第n个移动到C;然后再将1第n-2个圆盘看成是一个整体,将其通过你C移动到A,然后将第n-1个移动到C......以此类推,如下:





程序描述:
主函数:

自定义函数1
void Hanno(int n, char a, char b, char c)
函数功能:将a柱上面的n个圆盘移动到c柱上面。

自定义函数2
void Move(int i, char a, char b)
函数功能:描述将第i个圆盘从a柱移动到b柱

代码运行结果
n=1

n>=1

边栏推荐
- Greenplum 6.0有哪些不可错过的硬核升级与应用?
- Lake storehouse which electricity (2) of the project: project using technology and version and the environment
- 解码Redis最易被忽视的CPU和内存占用高问题
- Kubernetes之本地存储
- 云主机上的MongoDB被威胁,开启AUTH认证
- 初级永磁直线电机双动子电流镜像容错控制
- Anaconda\Scripts\pip-script.py is not present ? 解决方案
- 亚洲高校首现KDD博士论文奖:清华裘捷中获Runner Up奖,WINNER奖也是位华人
- 手慢无!阿里亿级流量高并发系统设计核心原理全彩笔记现实开源
- 别被隐私计算表象骗了 | 量子位智库报告(附下载)
猜你喜欢
随机推荐
ECCV 2022 | 新加坡国立大学提出:全新可恢复型模型遗忘框架LIRF!
什么是驱动程序签名,驱动程序如何获取数字签名?
双击Idea图标打不开——解决办法
These critical programs are missing or too old: ma
Anaconda\Scripts\pip-script.py is not present ? 解决方案
在 Scala 中读取整个文件
datax开启hana支持以及dolphinscheduler开启datax任务
EasyNVS云管理平台功能重构:支持新增用户、修改信息等
grep时排除指定的文件和目录
Js - 内置对象
Heshu Group: Make smart cities smarter and make real life better
no matching host key type found. Their offer: ssh-rsa
【MySQL系列】-B+树索引和HASH索引有什么区别
CMake library search function does not search LD_LIBRARY_PATH
[BJDCTF2020]Cookie is so stable-1|SSTI injection
关于香港高防IP需要关注的几个问题
结合实战,浅析GB/T28181(三)——实况点播
Xms Xmx PermSize MaxPermSize 区别
no matching host key type found. Their offer: ssh-rsa
来n遍剑指--04. 二维数组中的查找








