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

 更新时间:2022年07月08日 09:33:05   作者:hania_w  
递归(recursive)函数是“自己调用自己”的函数,无论是采用直接或间接调用方式。间接递归意味着函数调用另一个函数(然后可能又调用第三个函数等),最后又调用第一个函数。因为函数不可以一直不停地调用自己,所以递归函数一定具备结束条件

1、汉诺塔是如何实现的

下面是有三个盘子的示例:

从左到右一次是 A柱 B柱 C柱

A柱:起始位置

B柱:目标位置

C柱:过度位置

汉诺塔为题即是,将A柱上的所有盘子移动到B柱上,且每次只能移动一个盘子,并且小盘子必须在大盘子上面

2、汉诺塔问题画图详解

下面的例子是以A柱为起始位置,B柱为中间位置,C柱为目标位置的

如果初始状态下:A柱只有一个盘子:A->C

A柱有两个盘子:A->B A->C B->C

A柱有三个盘子:A->C A->B C->B A->C B->A

B->C A->C

下面我们画图来详细解释一下初始状态下为三个盘子的方法:

3、汉诺塔问题代码解释

//用c语言解决汉诺塔问题(函数递归)
#include<stdio.h>
//n:代表盘子的个数
//a:起始位置
//b:过度位置
//c:目的位置
void Move(char x1, char x2)
{
	printf("%c -> %c  ",x1,x2);//打印盘子的移动情况
}
void Hanoi(int n, char x1, char x2, char x3)
{
	if (n == 1)//递归的终止条件
	{
		Move(a, c);//当起始位置只有一个盘子时,直接将他挪到终止位置
	}
	else
	{
		Hanoi(n - 1, a, c, b);
		//将除掉最底部的一个盘子外,其余盘子通过起始位            
		//置A柱,过度位置C柱,最终移动到B柱上
		Move(a, c);//接着将A柱上的盘子直接移动到C柱上
		Hanoi(n - 1, b, a, c);
		//把B柱上的n-1个盘子,通过A柱,全部移动到C柱上
	}
}
int main()
{
	char a = 'A';
	char b = 'B';
	char c = 'C';
	int n = 0;
	printf("请输入起始位置的盘子数目:>");
	scanf("%d", &n);
	Hanoi(n, a, b, c);
	printf("\n");
	return 0;
}

当A柱起始位置有三个盘子是与我们分析的结果是一样的

总结

汉诺塔问题,需要用到递归思想,即从大到小考虑,

搞清楚每一步的起始位置与目标位置,巧妙借助过度位置的柱子去解决问题!

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

相关文章

  • VC6.0打开文件以及向工程中添加文件时程序崩溃自动退出解决方法

    VC6.0打开文件以及向工程中添加文件时程序崩溃自动退出解决方法

    vc6.0程序中,点击打开文件以及向工程中添加文件时,程序竟然崩溃自动退出了,不知什么原因,安装相同的vc程序,本本竟然出现此缘故
    2013-01-01
  • C++基于EasyX库实现拼图小游戏

    C++基于EasyX库实现拼图小游戏

    这篇文章主要为大家详细介绍了C++基于EasyX库实现拼图小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C++中对象的赋值与复制操作详细解析

    C++中对象的赋值与复制操作详细解析

    对象之间的赋值也是通过赋值运算符“=”进行的。本来赋值运算符“=”只能用来对单个的变量赋值,现在被扩展为两个同类对象之间的赋值,这是通过对赋值运算符的重载实现的
    2013-10-10
  • C++的内联函数你了解吗

    C++的内联函数你了解吗

    这篇文章主要为大家详细介绍了C++的内联函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • C语言 枚举类型(Enum)详解及示例代码

    C语言 枚举类型(Enum)详解及示例代码

    本文主要介绍C语言 枚举类型,这里提供了详细的相关资料及示例代码,以便大家学习参考,有兴趣的小伙伴可以参考下
    2016-08-08
  • C++详细讲解图的遍历

    C++详细讲解图的遍历

    图的遍历是指,从给定图中任意指定的顶点(称为初始点)出发,按照某种搜索方法沿着图的边访问图中的所有顶点,使每个顶点仅被访问一次,这个过程称为图的遍历
    2022-05-05
  • C++11 std::function和std::bind 的使用示例详解

    C++11 std::function和std::bind 的使用示例详解

    C++11中的std::function和std::bind是函数对象的重要组成部分,它们可以用于将函数和参数绑定在一起,形成一个可调用的对象,这篇文章主要介绍了C++11 std::function和std::bind 的使用示例详解,需要的朋友可以参考下
    2023-03-03
  • C++模拟实现string类的实例代码

    C++模拟实现string类的实例代码

    这篇文章主要给大家介绍了C++如何模拟实现string类,文章通过代码示例讲解的非常详细,有完整的实现过程,具有一定的参考价值,需要的朋友可以参考下
    2023-08-08
  • C/C++可变参数函数的实现

    C/C++可变参数函数的实现

    这篇文章主要介绍了C/C++可变参数函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • C++ float转std::string 小数位数控制问题

    C++ float转std::string 小数位数控制问题

    这篇文章主要介绍了C++ float转std::string 小数位数控制问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11

最新评论