iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言超详细讲解递归算法汉诺塔
  • 336
分享到

C语言超详细讲解递归算法汉诺塔

2024-04-02 19:04:59 336人浏览 安东尼
摘要

目录题目描述画图分析思路总结代码实现总结题目描述 汉诺塔问题起源于一个传说 汉诺塔又被称为河内塔,传说,在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。 印度教

题目描述

汉诺塔问题起源于一个传说

汉诺塔又被称为河内塔,传说,在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。

印度教的主神梵天在创造世界的时候,在其中一根针上从下到上地穿好了由大到小的64片金片,这就是所谓的汉诺塔。 不论白天黑夜,总有一个僧侣在按照下面的法则移动这些金片:一次只移动一片,不管在哪根针上,小片必须在大片上面。 僧侣们预言,当所有的金片都从梵天穿好的那根针上移到另外一根针上时,世界就将在一声霹雳中消灭,而梵塔、庙宇和众生也都将同归于尽。

我们现在要研究的就是在不同情况下盘子的移动顺序和移动的次数。

画图分析

由简到繁,我们先从最简单的情况来分析:

~~只有一个盘子的时候:

只有一个盘子我们直接把它从A柱移到C柱就行,此时移动次数是1,移动顺序是 A->C

~~有两个盘子的时候:

有两个盘子的时候我们需要先将较小的盘子移动到B柱,然后将较大的盘子移动C柱,再将B柱上的盘子移动到C柱;此时移动次数是3,移动顺序是 A->B A->C B->C

~~有三个盘子的时候:

有三个盘子的时侯,我们把最小的盘子命名为1,中间的为2,最大的为3,那么移动顺序应该是:1号移到到C柱,2号移动到B柱,1号移动到B柱,3号移动到C柱,1号移动到A柱,2号移动到C柱,1号移动到C柱;一共移动7次,移动顺序是A->C A->B C->B A->C B->A B->C A->C

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

A->C B->A

B->C A->C

思路总结

在上面的移动过程中,B柱始终起着中转的作用,我们我们可以理解为:

  • A柱:起始柱
  • B柱:中转柱
  • C柱:目标柱

同时,我们发现一个盘子时需要移动一次,两个盘子时需要移动3次,3个盘子时需要移动7次,所以总结规律:n个盘子需要移动的次数是 2n-1 次。

其次,我们可以把上面的移动过程简化为三个步骤:

  • 把n-1个盘子通过C柱移到B柱上。
  • 把A柱上的最后一个盘子移动到C柱上。
  • 把n-1个盘子通过A柱移动到C柱上。  

比如,上面盘子个数为三的时候,我们可以分解为:第一步:1号移到到C柱,2号移动到B柱,1号移动到B柱;第二步:3号移动到C柱;第三步:1号移动到A柱,2号移动到C柱,1号移动到C柱。

所以,n个盘子的移动顺序为:

1、把n-1个盘子通过C柱移到B柱上。

2. 把A柱上的最后一个盘子移动到C柱上。

3. 把n-1个盘子通过A柱移动到C柱上。

代码实现

#include<stdio.h>

//Move函数,用来移动盘子,pos1表示起始柱,pos2表示目标柱
void Move(char pos1, char pos2)
{
	printf("%c->%c ", pos1, pos2);  //把pos1的盘子移动到pos2
}

//Hanoi函数,用来实现汉诺塔,其中n表示盘子的个数,pos1表示起始柱,pos2表示中转柱,pos3表示目标柱
void Hanoi(int n, char pos1, char pos2, char pos3)
{
	if (1 == n)  //当n==1时,直接把盘子从A柱移动到C柱
	{
		Move(pos1, pos3);  
	}
	else   //当n不等于1时,分三步走
	{
		//第一步:将n-1个盘子通过C柱移动到B柱,此时C柱时中转柱,B柱是目标柱
		Hanoi(n - 1, pos1, pos3, pos2);
		//第二步:把A柱最后一个盘子直接移动到C柱
		Move(pos1, pos3);
		//第三步:将n-1个盘子通过A柱移动到C柱,此时B柱是起始柱,A柱是中转柱,C柱是目标柱
		Hanoi(n - 1, pos2, pos1, pos3);
	}
}
int main()
{
	//定义一个变量来表示盘子的个数
	int n = 0;   
	//定义三个字符变量来表示三根柱子
	char pos1 = 'A';
	char pos2 = 'B';
	char pos3 = 'C';
	//调用hanoi函数
	Hanoi(1, pos1, pos2, pos3);  //n为1
	printf("\n");
	Hanoi(2, pos1, pos2, pos3);  //n为2
	printf("\n");
	Hanoi(3, pos1, pos2, pos3);  //n为3
	printf("\n");
	Hanoi(4, pos1, pos2, pos3);  //n为4
	printf("\n");
	return 0;
}

总结

知道了汉诺塔的逻辑后,我们重新回到这个问题,我们发现,要把64片金片全部挪完需要挪动 264-1 次,假设这个僧侣一秒钟移动一次,那么一共要挪 (264-1) / 3600 / 24 / 365 = 584,942,417,355(年),那时候地球已经毁灭也不是没有可能,哈哈。

到此这篇关于C语言超详细讲解递归算法汉诺塔的文章就介绍到这了,更多相关C语言汉诺塔内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C语言超详细讲解递归算法汉诺塔

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

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

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

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

下载Word文档
猜你喜欢
  • C语言超详细讲解递归算法汉诺塔
    目录题目描述画图分析思路总结代码实现总结题目描述 汉诺塔问题起源于一个传说 汉诺塔又被称为河内塔,传说,在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。 印度教...
    99+
    2024-04-02
  • C语言编程递归算法实现汉诺塔
    汉诺塔 法国数学家爱德华·卢卡斯曾编写过一个印度的古老传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。印度教的主神梵天在创造世界的时候,在其中一根针上从下...
    99+
    2024-04-02
  • C语言递归思想实现汉诺塔详解
    目录1.递归思想简介2.汉诺塔问题3.汉诺塔递归的c语言实现总结1.递归思想简介 在c语言中,程序调用自身的编程技巧称为递归( recursion)。 递归的定义看上去似乎很抽象,使...
    99+
    2024-04-02
  • C语言递归:汉诺塔问题分析
    目录问题背景游戏体验汉诺塔移动次数规律移动过程的深层解读汉诺塔问题的三步过程归纳图解:发现:代码实现1仅打印移动次数代码实现2打印移动的具体过程补充问题背景 汉诺塔问题源自印度一个古...
    99+
    2023-01-28
    c语言递归汉诺塔 C语言递归汉诺塔每一步详解 汉诺塔c程序的递归原理
  • C#利用递归算法解决汉诺塔问题
    目录一、什么是递归二、汉诺塔问题1.汉诺塔的故事2.解决思路3.怎么解决汉诺塔问题4.具体代码实现三、完整代码一、什么是递归 方法调用自己的行为就是递归,递归必须要有终止条件,不然它...
    99+
    2024-04-02
  • C语言用递归函数实现汉诺塔
    目录汉诺塔(Hanoi)是什么?那么,C语言如何实现汉诺塔呢?汉诺塔的基本思路是:具体代码见下(注意点在代码下面):总结汉诺塔(Hanoi)是什么? 一个简单的汉诺塔就如上图所示...
    99+
    2024-04-02
  • C#怎么利用递归算法解决汉诺塔问题
    本篇内容介绍了“C#怎么利用递归算法解决汉诺塔问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是递归方法调用自己的行为就是递归,递...
    99+
    2023-06-30
  • C语言运用函数的递归实现汉诺塔
    目录1、汉诺塔是如何实现的2、汉诺塔问题画图详解3、汉诺塔问题代码解释总结1、汉诺塔是如何实现的 下面是有三个盘子的示例: 从左到右一次是 A柱 B柱 C柱 A柱:起始位置 B柱:...
    99+
    2024-04-02
  • C语言递归函数与汉诺塔问题简明理解
    目录递归函数Hanio(汉诺塔)问题递归函数 直接或者间接调用函数本身。“自己调用自己” 什么情况下面可以使用递归呢 解决一个问题时,解决思路化成与问题本身类...
    99+
    2024-04-02
  • C语言递归函数与汉诺塔问题怎么解决
    今天小编给大家分享一下C语言递归函数与汉诺塔问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。递归函数直接或者间接调...
    99+
    2023-07-02
  • Java与C++分别用递归实现汉诺塔详解
    目录1.汉诺塔介绍2.解塔步骤3.C++实现(递归结果及显示步骤)(1)递归结果(2)显示步骤4.Java实现(递归结果及显示步骤)(1)递归结果(2)显示步骤1.汉诺塔介绍 汉诺...
    99+
    2024-04-02
  • C语言超细致讲解函数递归
    目录前言什么是递归递归的两个必要条件题解递归递归与迭代练习题结束语前言 最近被函数递归困恼许久,今天就带领大家一起探秘递归。 什么是递归 程序调用自身的编程技巧称为递归( recur...
    99+
    2024-04-02
  • Java用递归方法解决汉诺塔问题详解
    目录前言一、问题描述二、问题分析三、解决方案四、示例前言 博主之前有写过关于递归问题的思维模式: 递归的思路 下面将用这种思维模式来求解经典汉诺塔问题。 一、问题描述 汉诺塔(又称河...
    99+
    2024-04-02
  • C语言怎么运用函数的递归实现汉诺塔
    这篇文章主要讲解了“C语言怎么运用函数的递归实现汉诺塔”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言怎么运用函数的递归实现汉诺塔”吧!1、汉诺塔是如何实现的下面是有三个盘子的示例:从左...
    99+
    2023-07-02
  • C语言递归之汉诺塔和青蛙跳台阶问题
    递归就是一个函数执行过程中调用自己,在c语言中有很多关于递归的经典问题,例如:斐波那契数列问题、汉诺塔问题等,在研究递归问题时我们要注意三点: 1.递归的结束条件 2.递归在每次进行...
    99+
    2024-04-02
  • Java递归来实现汉诺塔游戏,注释详细
    我们很容易能想到,可以用递归来实现汉诺塔游戏。因为要将n(n>1)个盘子从“源”柱子移到“目标”柱子,我们要先把n-1个盘子从“源”柱子移到“辅助”柱子上,然后把最底下那一个盘...
    99+
    2024-04-02
  • C语言实现汉诺塔(图文详解)
    目录思路:当n=1时:当n=2时:当n=3时:当n=4时:见代码运行截图总结汉诺塔的游戏规则: 有三根金刚石柱子A、B、C,在A柱子上从下往上按照大小依次减小的顺序摞着64片黄金环。...
    99+
    2024-04-02
  • JavaScript中递归函数解“汉诺塔”算法的示例分析
    小编给大家分享一下JavaScript中递归函数解“汉诺塔”算法的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!“汉诺塔...
    99+
    2024-04-02
  • java基于递归算法实现汉诺塔问题实例
    本文实例讲述了java基于递归算法实现汉诺塔问题。分享给大家供大家参考,具体如下:package test;import java.util.List;import java.util.ArrayList;import java.util....
    99+
    2023-05-31
    java 递归算法 汉诺塔
  • JavaSE递归求解汉诺塔问题的思路与方法
    目录1. 汉诺塔的介绍和玩法2. 汉诺塔问题的思路3. 用递归的代码实现 总结1. 汉诺塔的介绍和玩法 汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古...
    99+
    2022-11-13
    javase递归求解汉诺塔 用递归求解汉诺塔问题 递归实现汉诺塔问题java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作