我的编程空间,编程开发者的网络收藏夹
学习永远不晚

带你理解C语言中的汉诺塔公式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

带你理解C语言中的汉诺塔公式

汉诺塔公式

汉诺塔问题在数学层面的公式:

不用说,你看到这个公式一定一脸懵逼,我现在来讲解这个公式的作用。

先来回想一下大象放冰箱要几步,三步吧,打开冰箱,放进去,关上门就行了,我们先不要去思考一些细碎的步骤,将一个复杂的问题先简单化,再慢慢去分析。

那汉诺塔问题也是同样的简单三步:(假设有n个盘子)

一、把最大的盘子留在A柱,然后将其他的盘子全放在B柱。

二、把最大的盘子放到C柱。

三、然后将B柱上的所有盘子放到C柱。

这就是汉诺塔的流程,汉诺塔的精髓就是上面三句话。

n层汉诺塔有(2^n-1)次移动,来将盘子全部从A盘到C盘.

C语言递归公式

相应我们可以写出对应的C语言递归公式:(n就是盘子的个数,xyz就是柱子的名字)

相信你肯定有很多疑问,我们现在先来举几个例子再解释问题吧。

 一个盘子就不说了,因为最大的盘子就是他,所以他直接就去C盘了。

两层汉诺塔

共三步:把最大盘上面的全部放到B,然后最大盘去C,再把剩余的盘全部放到C就行了。

这是两个盘,共移动三次就移动完了,那三个盘呢?

三层汉诺塔

 把全部过程堪称一个整体,最大盘上面的所有盘全部看成一个整体,我们也只用执行三个步骤,我们要利用把大事化小的观点,不要一上来就思考具体是怎么移动的,这样看不清问题的本质。

我们再来具体分析三步具体要怎么移动.

第一步中,我们要移动三次,分别是A->C、是A->B、C->B这就是一大次完整的移动,在这一步中,我们套用了上一次的汉诺塔公式进行使用,这就是汉诺塔的难点,接下来我给大家看个图,希望大家能理解,(n是层数,X,Y,Z则是函数参数)

 汉诺塔的内部其实就像一个金字塔一样,其实每一次调用自己,就是按照上面所说精髓的公式调用自己,让自己的参数发生了变化。我希望大家能够自己去照着画一下流程,

第二步:将A到C,这就是将上图的第二步那写上第四次移动:A->C。

第三步,将B柱上的全部盘子借助A放到C

第七步完成后就会发现没有要执行的语句了,汉诺塔函数就结束返回到main函数了,自此求解汉诺塔函数的步骤就完成了。

好的,这样,我们移动三层汉诺塔的过程的就完成了,三次汉诺塔完成就算是解决了这个问题,因为即使盘子再多也就是一样的公式套用而已,明白两层和三层汉诺塔的运行原理就可以了,再多层的塔也是相同的流程。不难发现,递归就是让数学公式在C语言中体现了出来,让问题变的十分”简单“。

剩下就是了程序的主函数部分了,这个问题的主函数就很简单,主函数只用传来盘子的数量和三个柱子的名字就行了;代码如下

#include <stdio.h>
void change (char x,char y)     //打印盘子移动轨迹的函数
{
    printf("%c->%c\n", x, y);
}
void f(n, x, y, z)              //汉诺塔函数
{
    if (n == 1)
    {
        change(x, z);
    }
    else
    {
        f(n - 1, x, z, y);      //公式一:将A柱最大盘外的盘子借助C柱移到B柱
            change(x, z);       //公式二:将A上最大盘移动到C柱
        f(n - 1, y, x, z);      //公式三:将B柱上的盘借助A全部放到C柱
    }
}
int main()
{
    int m;
    scanf("%d", &m);
    f(m, 'A', 'B', 'C');
}

总结

到此这篇关于带你理解C语言中的汉诺塔公式的文章就介绍到这了,更多相关C语言汉诺塔公式内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

带你理解C语言中的汉诺塔公式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C语言中的汉诺塔公式是什么

这篇文章主要为大家展示了“C语言中的汉诺塔公式是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中的汉诺塔公式是什么”这篇文章吧。汉诺塔公式汉诺塔问题在数学层面的公式:不用说,你看到这个
2023-06-28

一文带你深入理解Go语言中的sync.Cond

sync.Cond 表示的是条件变量,它是一种同步机制,用来协调多个 goroutine 之间的同步。本文将通过示例为大家介绍Go语言中sync.Cond的使用,需要的可以参考一下
2023-01-31

一文带你了解C语言中static关键字的3个作用

static这个关键字是“静态”的意思,在C语言里主要有3个作用。这篇文章主要通过一些简单示例为大家详细讲讲这3个左右,感兴趣的小伙伴可以了解一下
2023-05-15

一文带你了解C语言中的0长度数组(可变数组/柔性数组)

众所周知, GNU/GCC 在标准的 C/C++ 基础上做了有实用性的扩展, 零长度数组(Arrays of Length Zero) 就是其中一个知名的扩展,本文就来聊聊零长度数组的相关知识吧
2023-03-19

如何理解C语言数据结构中线性表的链式存储结构

如何理解C语言数据结构中线性表的链式存储结构,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.什么是线性表的链式存储结构 —链表存储结点:包括元素本身的信息,还有元素之间的关系
2023-06-21

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录