iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言怎么实现汉诺塔
  • 284
分享到

C语言怎么实现汉诺塔

2023-06-28 20:06:57 284人浏览 独家记忆
摘要

这篇文章主要介绍了C语言怎么实现汉诺塔的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言怎么实现汉诺塔文章都会有所收获,下面我们一起来看看吧。1.递归思想简介在c语言中,程序调用自身的编程技巧称为递归( re

这篇文章主要介绍了C语言怎么实现汉诺塔的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言怎么实现汉诺塔文章都会有所收获,下面我们一起来看看吧。

1.递归思想简介

在c语言中,程序调用自身的编程技巧称为递归( recursion)。

递归的定义看上去似乎很抽象,使用代码描述能够让人容易理解,下面是一个函数递归的例子。

  int factorial(int n)  //定义一个求阶乘的函数叫做factorial(),需要一个整形参数,返回一个整形值{if (n <= 1)       //递归结束的条件{return 1;}else{return n * factorial(n - 1);//在factorial()中再次调用自身,只不过参数由n变成n-1}}

在这个例子中,函数 factorial()接收到一个整形数n,如n=5,暂时称作F(5),这时n!=F(5),而函数的功能如下:

判断5是否小于或等于1,如果是,将1返回;不是,进到else执行语句返回(这里可以将return看作等于)5&times; factorial(n - 1),等价于 F(5)=5&times;F(4)用上面的方法计算F(4)=4&times;F(3)....以此类推直到达到限制条件n=1时有,F(1)=1

递归算法的实质:是把问题转化为规模缩小了的同类问题的子问题。然后递归调用函数(或过程)来表示问题。

由于每个小问题处理起来都有与大问题类似的行为逻辑,因此我们可以“大事化小”,而递归说白了,就是不断地在套娃。

但是,计算机的内存是有限的,由于每次调用函数都需要在栈区开辟一个空间,使得递归不能无限制地进行下去,没有递归结束的条件,当操作系统为进程分配的虚拟地址空间当中的栈空间被耗尽时,会发生堆栈溢出,产生段错误(segmentation fault)。

因此,使用递归时应注意:

必须存在限制条件,当满足这个限制条件的时候,递归便不再继续每次递归调用之后越来越接近这个限制条件 

递归的好处在于:

代码简洁在某些特定问题上求解方便

递归的缺点在于

消耗大量时间和空间资源&mdash;&mdash;效率较低可能伴随许多重复计算,工作量大&mdash;&mdash;影响性能

2.汉诺塔问题

以下内容来自维基百科

最早发明这个问题的人是法国数学家爱德华&middot;卢卡斯。

传说越南河内某间寺院有三根银棒,上串 64 个金盘。寺院里的僧侣依照一个古老的预言,以上述规则移动这些盘子;预言说当这些盘子移动完毕,世界就会灭亡。这个传说叫做梵天寺之塔问题(Tower of Brahma puzzle)。但不知道是卢卡斯自创的这个传说,还是他受他人启发。

若传说属实,僧侣们需要C语言怎么实现汉诺塔步才能完成这个任务;若他们每秒可完成一个盘子的移动,就需要 5849 亿年才能完成。整个宇宙现在也不过 137 亿年。

这个传说有若干变体:寺院换成修道院、僧侣换成修士等等。寺院的地点众说纷纭,其中一说是位于越南的河内,所以被命名为“河内塔”。另外亦有“金盘是创世时所造”、“僧侣们每天移动一盘”之类的背景设定

汉诺塔基本的玩法如图,其规则是:将圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。 

C语言怎么实现汉诺塔

 当圆盘数量只有3个的时候,求解的方法显而易见,但当数量增多时,问题变得有些棘手起来。但不管怎么移动,核心思想都是递归:

先从n块圆盘中将最大的一块移动到最后的柱子上接着从剩下n-1找到最大的一块移到柱子上...... 

3.汉诺塔递归的c语言实现

C语言代码如下:

  #define _CRT_SECURE_NO_WARNINGS#include<stdio.h> void move(char, char); // 声明一个函数move,函数定义在下方,用于表示圆盘的交换 void Towers_Of_Hanoi(int n,char a,char b,char c) {if (1 == n)                        //递归结束标志:当柱子上只有一块圆盘{move(a, c);                    //从a移动到c}elseTowers_Of_Hanoi(n - 1, a, c, b);    //将最上面n-1个圆盘移动到b柱上move(a, c);                         //将a上面最后一块圆盘移动到c柱上Towers_Of_Hanoi(n - 1, b, a, c);    //将b柱上n-1个圆盘移动到a柱上}} void move(char x, char y){printf("%c-->%c\n", x, y);} int main(){int n = 0;scanf("%d", &n);Towers_Of_Hanoi(n, 'A', 'B', 'C');//n为A柱子上圆盘的数量,A,B,C代表三根柱子return 0;}

程序运行结果为:

C语言怎么实现汉诺塔

关于“C语言怎么实现汉诺塔”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“C语言怎么实现汉诺塔”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网其他教程频道。

--结束END--

本文标题: C语言怎么实现汉诺塔

本文链接: https://www.lsjlt.com/news/321071.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • C语言怎么实现汉诺塔
    这篇文章主要介绍了C语言怎么实现汉诺塔的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言怎么实现汉诺塔文章都会有所收获,下面我们一起来看看吧。1.递归思想简介在c语言中,程序调用自身的编程技巧称为递归( re...
    99+
    2023-06-28
  • C语言实现汉诺塔(图文详解)
    目录思路:当n=1时:当n=2时:当n=3时:当n=4时:见代码运行截图总结汉诺塔的游戏规则: 有三根金刚石柱子A、B、C,在A柱子上从下往上按照大小依次减小的顺序摞着64片黄金环。...
    99+
    2024-04-02
  • c语言怎么循环加数组实现汉诺塔
    今天小编给大家分享一下c语言怎么循环加数组实现汉诺塔的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。简介汉诺塔问题是学数据结构...
    99+
    2023-06-29
  • C语言用递归函数实现汉诺塔
    目录汉诺塔(Hanoi)是什么?那么,C语言如何实现汉诺塔呢?汉诺塔的基本思路是:具体代码见下(注意点在代码下面):总结汉诺塔(Hanoi)是什么? 一个简单的汉诺塔就如上图所示...
    99+
    2024-04-02
  • c语言汉诺塔问题怎么解决
    解决汉诺塔问题的常见方法是使用递归。以下是使用递归解决C语言汉诺塔问题的示例代码:```c#include void hanoi(i...
    99+
    2023-10-07
    c语言
  • C语言编写汉诺塔游戏
    目录汉诺塔的游戏规则:当A只有一个环的时候:当A只有两个环的时候:当A只有三个环的时候:思路:当n=1时:当n=2时:当n=3时:当n=4时:见代码运行截图总结汉诺塔的游戏规则:  ...
    99+
    2024-04-02
  • C语言递归思想实现汉诺塔详解
    目录1.递归思想简介2.汉诺塔问题3.汉诺塔递归的c语言实现总结1.递归思想简介 在c语言中,程序调用自身的编程技巧称为递归( recursion)。 递归的定义看上去似乎很抽象,使...
    99+
    2024-04-02
  • C语言编程递归算法实现汉诺塔
    汉诺塔 法国数学家爱德华·卢卡斯曾编写过一个印度的古老传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。印度教的主神梵天在创造世界的时候,在其中一根针上从下...
    99+
    2024-04-02
  • 怎么用c语言编写汉诺塔程序
    以下是使用C语言编写汉诺塔程序的示例代码: #include void hanoi(int n, char from, char...
    99+
    2023-10-23
    c语言
  • C语言怎么运用函数的递归实现汉诺塔
    这篇文章主要讲解了“C语言怎么运用函数的递归实现汉诺塔”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言怎么运用函数的递归实现汉诺塔”吧!1、汉诺塔是如何实现的下面是有三个盘子的示例:从左...
    99+
    2023-07-02
  • c语言循环加数组实现汉诺塔问题
    目录简介递归的汉诺塔解法(c语言)循环实现汉诺塔问题(c语言)简介 汉诺塔问题是学数据结构与算法的时候会遇到的问题,相信来看本文的读者应该都对汉诺塔问题有基本的了解,理论上所有的递归...
    99+
    2024-04-02
  • java怎么实现汉诺塔
    以下是一个使用Java实现汉诺塔问题的示例代码: public class HanoiTower { public stat...
    99+
    2023-10-23
    java
  • C语言运用函数的递归实现汉诺塔
    目录1、汉诺塔是如何实现的2、汉诺塔问题画图详解3、汉诺塔问题代码解释总结1、汉诺塔是如何实现的 下面是有三个盘子的示例: 从左到右一次是 A柱 B柱 C柱 A柱:起始位置 B柱:...
    99+
    2024-04-02
  • C语言中的汉诺塔公式是什么
    这篇文章主要为大家展示了“C语言中的汉诺塔公式是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中的汉诺塔公式是什么”这篇文章吧。汉诺塔公式汉诺塔问题在数学层面的公式:不用说,你看到这个...
    99+
    2023-06-28
  • C语言递归:汉诺塔问题分析
    目录问题背景游戏体验汉诺塔移动次数规律移动过程的深层解读汉诺塔问题的三步过程归纳图解:发现:代码实现1仅打印移动次数代码实现2打印移动的具体过程补充问题背景 汉诺塔问题源自印度一个古...
    99+
    2023-01-28
    c语言递归汉诺塔 C语言递归汉诺塔每一步详解 汉诺塔c程序的递归原理
  • PHP怎么实现汉诺塔算法
    本篇内容介绍了“PHP怎么实现汉诺塔算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!        ...
    99+
    2023-06-20
  • C 语言基础实现青蛙跳台阶和汉诺塔问题
    目录一、青蛙跳台阶题目思路分析1. 从跳法次数分析2. 从过程分析二、青蛙跳台阶变式1题目分析三、青蛙跳台阶变式2题目分析四、汉诺塔问题(求步数)题目思路分析五、汉诺塔问题(求移动过...
    99+
    2024-04-02
  • 带你理解C语言中的汉诺塔公式
    目录汉诺塔公式汉诺塔问题在数学层面的公式:C语言递归公式两层汉诺塔三层汉诺塔总结汉诺塔公式 汉诺塔问题在数学层面的公式: 不用说,你看到这个公式一定一脸懵逼,我现在来讲解这个公式的...
    99+
    2024-04-02
  • Python3实现汉诺塔问题
    Python3实现汉诺塔问题一、思路二、Python3代码实现三、总结四、参考资料 总结归纳为以下3步: 把x上的n-1个盘子借助z,移动到y上 把x上最下面的盘子移动到z上 最后把y上的n-1个盘子借助x移动到,z上,大功告...
    99+
    2023-01-31
    汉诺
  • C语言递归函数与汉诺塔问题怎么解决
    今天小编给大家分享一下C语言递归函数与汉诺塔问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。递归函数直接或者间接调...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作