服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言用递归函数实现汉诺塔

C语言用递归函数实现汉诺塔

2022-09-02 13:21蔡欣致 C/C++

大家好,本篇文章主要讲的是C语言用递归函数实现汉诺塔,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下

汉诺塔(Hanoi)是什么?

C语言用递归函数实现汉诺塔

C语言用递归函数实现汉诺塔

一个简单的汉诺塔就如上图所示,有三个放置点,放置物必须遵循上小下大的规则,依次将1中的放置物全部放置到3中。就比如该图中有4个放置物,若将A上的放置物全部移至C上,具体的步骤是:A->B A->C B->C A->B C->A C->B A->B A->C B->C B->A C->A B->C A->B A->C B->C。

 

那么,C语言如何实现汉诺塔呢?

第一步要先确定起始位置、中转位置、目的位置,在一开始A是起始位置,B是中转位置,C是目的位置,在后续移动物块的时候会一直改变这三个位置的功能,以达到最终目标。

 

汉诺塔的基本思路是:

第一阶段:将n-1个物块(也就是除最底部的物块外)经过一系列地堆放(这里就可以使用到递归的方法来实现),最后放置到中转位置上,然后把起始位置剩下的物块放到目的位置上,如下图:

C语言用递归函数实现汉诺塔

C语言用递归函数实现汉诺塔

 以上一系列地堆放是指:以A为起始位置,C为中转位置,B为目的位置,也就相当于把C看作是一个中间存放点,来帮助这n-1个物块放到B里面去。

第二阶段:然后会发现,变化后的汉诺塔的形式也和之前是差不多的,如果把B看作是起始位置,A是中转位置,C是目的位置。就可以一直按照上面的那个方法一直递归下去,如下图:

C语言用递归函数实现汉诺塔

C语言用递归函数实现汉诺塔

以此类推……最后就能实现把所有的物块全部从A搬到C。

 

具体代码见下(注意点在代码下面):

//C语言实现汉诺塔
#include <stdio.h>
 
void move(char p1, char p2)
{
	printf("%c->%c  ", p1, p2);
}
 
//n:个数  pos1:起始位置  pos2:中转位置  pos3:目的位置
void Hanoi(int n, char pos1, char pos2, char pos3)
{
	if (n == 1)
	{
		move(pos1, pos3);
	}
	else
	{
		Hanoi(n - 1, pos1, pos3, pos2);
		move(pos1, pos3);
		Hanoi(n - 1, pos2, pos1, pos3);
	}
}
 
int main()
{
	Hanoi(1, "A", "B", "C");
	printf("
");
	Hanoi(2, "A", "B", "C");
	printf("
");
	Hanoi(3, "A", "B", "C");
	printf("
");
	Hanoi(4, "A", "B", "C");
	printf("
");
	return 0;
}

注意点一:代码中的n值不能太大,因为移动次数是随n的增大呈指数倍增长。

注意点二:n为1的时候已近到达最小单位(也就是最底层),不需要使用递归;n为大于1的值时,需要递归到1才能进行。

注意点三:第一阶段使用递归表示的是把上面n-1层全部移到B中;而第二阶段使用递归表示的是把B中全部移到C中。

 

总结

这样就可以简单地完成汉诺塔,此代码并不是最优方法,但是理解起来比较容易。递归在实际中运用的不是很多,但是也要看得懂代码和写出类似这种汉诺塔等递归函数的基础代码。

到此这篇关于C语言用递归函数实现汉诺塔的文章就介绍到这了,更多相关C语言汉诺塔内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Faith_cxz/article/details/122635557

延伸 · 阅读

精彩推荐
  • C/C++将正小数转化为2-9进制小数的实现方法

    将正小数转化为2-9进制小数的实现方法

    本篇文章对正小数转化为2-9进制小数的实现方法进行了介绍,需要的朋友参考下...

    C语言教程网4972020-11-27
  • C/C++opencv2实现10张图像上下左右拼接融合

    opencv2实现10张图像上下左右拼接融合

    这篇文章主要为大家详细介绍了opencv2实现10张图像上下左右拼接融合,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一...

    米姒翰10162021-08-21
  • C/C++手把手教你用C语言实现三子棋

    手把手教你用C语言实现三子棋

    三子棋是黑白棋的一种。三子棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、井字棋等。这篇文章就教你如何用C语言实现三子棋的功能...

    你帅你先说.6342021-12-14
  • C/C++C语言打印某一年的日历

    C语言打印某一年的日历

    这篇文章主要为大家详细介绍了C语言打印某一年的日历,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    带着你的名字9462021-11-15
  • C/C++C语言 function recursion函数递归详解

    C语言 function recursion函数递归详解

    递归指的是在函数的定义中使用函数自身的方法,举个例子: 从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?"从前...

    Dark And Grey9232022-02-12
  • C/C++C 语言中实现环形缓冲区

    C 语言中实现环形缓冲区

    本文主要是介绍 C语言实现环形缓冲区,并附有详细实现代码,具有一定的参考价值,希望能帮助有需要的小伙伴...

    C语言教程网4222021-04-09
  • C/C++使用C语言中的time函数获取系统时间

    使用C语言中的time函数获取系统时间

    在C语言中可以使用time函数来获取系统时间,以下对time函数进行了介绍,需要的朋友可以过来参考下...

    C语言教程网4702020-12-20
  • C/C++C语言基于贪心算法解决装箱问题的方法

    C语言基于贪心算法解决装箱问题的方法

    这篇文章主要介绍了C语言基于贪心算法解决装箱问题的方法,简单描述了装箱问题,并结合实例形式给出了C语言使用贪心算法解决贪心问题的相关操作技巧...

    忆之逸之11282021-06-26