IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【C语言】汉诺塔问题 -> 正文阅读

[C++知识库]【C语言】汉诺塔问题

汉诺(Hanoi)塔问题:假设有命名为A、B、C的三个塔柱,初始时,在塔柱A上插有n个直径大小各不相同的圆盘,从上往下,圆盘从小到大编号为1、2、3、···n,要求将A柱上的圆盘移至塔柱C,可借助塔柱B,用程序模拟搬盘子过程。本程序要求用非递归算法的程序实现 (n<=6)。 圆盘移动必须遵守下列规则: 1:每次只能移动一个圆盘; 2:圆盘可以插在任意一个塔柱上; 3:任何时刻都不能将一个较大的圆盘放在一个较小的圆盘上。

输入格式:

正整数n。

输出格式:

搬盘子过程,每行一次搬动。

输入样例:

3

输出样例:

A->C
A->B
C->B
A->C
B->A
B->C
A->C

代码如下:

#include <stdio.h>
#include <stdlib.h>
//Hanoi
void Hanoi(int n, char A, char B, char C);

int main()
{
    //设立盘子个数
    int n = 0;

    //输入盘子个数
    scanf("%d",&n);

    //递归函数
    Hanoi(n,'A','B','C');//传入ABC三个柱子 A:起始位置 B:经过位置 C:最终位置
    return 0;
}

//move
void move(char x, char y) {//x:起始位置 y:终止位置
        printf("%c->%c\n",x, y);
}

//Hanoi
void Hanoi(int n, char A, char B, char C) {
    //处理一个盘子
    if(n == 1) {
        move(A, C);
    }

    //处理n-1个盘子
    else {
        Hanoi(n - 1, A, C, B);//第一步将n-1个盘子从A经过C移到B
        move(A, C);//第二步将剩余盘子从A移到C
        Hanoi(n - 1, B, A, C);//第三步将n-1个盘子从B经过A移到C
    }

}

核心关键

作者:Fireman A
链接:https://www.zhihu.com/question/24385418/answer/257751077
来源:知乎

对递归的理解的要点主要在于放弃!

放弃你对于理解和跟踪递归全程的企图,只理解递归两层之间的交接,以及递归终结的条件。

想象你来到某个热带丛林,意外发现了十层之高的汉诺塔。正当你苦苦思索如何搬动它时,林中出来一个土著,毛遂自荐要帮你搬塔。他名叫二傻,戴着一个草帽,草帽上有一个2字,号称会把一到二号盘搬到任意柱。

你灵机一动,问道:“你该不会有个兄弟叫三傻吧?”
“对对,老爷你咋知道的?他会搬一到三号盘。“
”那你去把他叫来,我不需要你了。“
于是三傻来了,他也带着个草帽,上面有个3字。

你说:”三傻,你帮我把头三个盘子移到c柱吧。“
三傻沉吟了一会,走进树林,你听见他大叫:”二傻,出来帮我把头两个盘子搬到C!“

由于天气炎热你开始打瞌睡。朦胧中你没看见二傻是怎么工作的,二傻干完以后,走入林中大叫一声:“老三,我干完了!”

三傻出来,把三号盘从A搬到B,然后又去叫二傻:“老二,帮我把头两个盘子搬回A!”

余下的我就不多说了,总之三傻其实只搬三号盘,其他叫二傻出来干。最后一步是三傻把三号盘搬到C,然后呼叫二傻来把头两个盘子搬回C

事情完了之后你把三傻叫来,对他说:“其实你不知道怎么具体一步一步把三个盘子搬到C,是吧?”

三傻不解地说:“我不是把任务干完了?”

你说:“可你其实叫你兄弟二傻干了大部分工作呀?”

三傻说:“我外包给他和你屁相干?”

你问到:“二傻是不是也外包给了谁?“

三傻笑了:“这跟我有屁相干?”

你苦苦思索了一夜,第二天,你走入林中大叫:“十傻,你在哪?”

一个头上带着10号草帽的人,十傻,应声而出:“老爷,你有什么事?”

“我要你帮把1到10号盘子搬到C柱“

“好的,老爷。“十傻转身就向林内走。

“慢着,你该不是回去叫你兄弟九傻吧“

“老爷你怎么知道的?“

“所以你使唤他把头九个盘子搬过来搬过去,你只要搬几次十号盘就好了,对吗?“

“对呀!“

“你知不知道他是怎么干的?“

“这和我有屁相干?“

你叹了一口气,决定放弃。十傻开始干活。树林里充满了此起彼伏的叫声:“九傻,来一下!“ “老八,到你了!““五傻!。。。“”三傻!。。。“”大傻!“

你注意到大傻从不叫人,但是大傻的工作也最简单,他只是把一号盘搬来搬去。

若干年后,工作结束了。十傻来到你面前。你问十傻:“是谁教给你们这么干活的?“

十傻说:“我爸爸。他给我留了这张纸条。”

他从口袋里掏出一张小纸条,上面写着:“照你帽子的号码搬盘子到目标柱。如果有盘子压住你,叫你上面一位哥哥把他搬走。如果有盘子占住你要去的柱子,叫你哥哥把它搬到不碍事的地方。等你的盘子搬到了目标,叫你哥哥把该压在你上面的盘子搬回到你上头。“

你不解地问:“那大傻没有哥哥怎么办?“

十傻笑了:“他只管一号盘,所以永远不会碰到那两个‘如果’,也没有盘子该压在一号上啊。”

但这时他忽然变了颜色,好像泄漏了巨大的机密。他惊慌地看了你一眼,飞快地逃入树林。

第二天,你到树林里去搜寻这十兄弟。他们已经不知去向。你找到了一个小屋,只容一个人居住,但是屋里有十顶草帽,写着一到十号的号码。

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-31 23:45:54  更:2022-03-31 23:48:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 2:18:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码