例子:三阶hanoi塔 C语言程序图解分析

  前言:在学习递归过程中,书中举例了hanoi塔的例子,代码很少,但我不理解其编写原理,于是逐步分析记录了每个变量的变化,并将其流程以图的形式表达出来,以供以后复习!

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

程序代码(三阶为例):

#include <stdio.h>

void hanoi(int n, char A, char B, char C)//将n个圆盘从A柱移动到C柱,借助B作为辅助柱 
{
	if(n == 1)
	{
		printf("%c -> %c\n", A, C);		//将圆盘从A移动到C 
	}
	else
	{
		hanoi(n-1, A, C, B);			//将A上编号1至n-1的圆盘移动到B,C做辅助塔 
		printf("%c -> %c\n", A, C);		//将圆盘从A移动到C 
		hanoi(n-1, B, A, C);			//将B上编号1至n-1的圆盘移动到C,A做辅助塔 
	}
}


int main(int argc, char** argv) {
	hanoi(3, 'A', 'B', 'C');			//三阶hanoi塔 

	return 0;
}

图解分析:

其中,我认为每次对于hanoi(int n, char A, char B, char C)中A,B,C的形参实参的理解及赋值问题,是困扰我的地方。

 

欢迎一起探讨问题!

如有不正确的地方,请不要吝啬指正!

谢谢阅读!

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hanoi是一个经典的递归问题,它可以用C语言来实现。Hanoi问题的规则是,有三根柱子A、B、C,以及n个不同大小的圆盘,初始时,所有圆盘都放在柱子A上,目标是将所有圆盘从A柱子移动到C柱子上,每次只能移动一个圆盘,并且大的圆盘不能放在小的圆盘上面。 要解决Hanoi问题,可以使用递归的方法。递归的思想是将大问题分解成一个个小问题来解决,然后通过组合小问题的解来解决整个问题。 在这个问题中,我们可以将n个圆盘的移动分解为三个步骤: 1. 将n-1个圆盘从A柱子移动到B柱子上; 2. 将最大的一个圆盘从A柱子移动到C柱子上; 3. 将n-1个圆盘从B柱子移动到C柱子上。 这样,问题就被分解成了三个小问题,而这三个小问题与原问题的规模相比减小了,因此可以使用递归的方法来解决。 具体的C语言递归代码如下: ```c void hanoi(int n, char source, char auxiliary, char target) { if (n == 1) { // 只有一个圆盘时,直接从source柱子移动到target柱子上 printf("Move disk from %c to %c\n", source, target); return; } hanoi(n-1, source, target, auxiliary); // 递归调用步骤1 printf("Move disk from %c to %c\n", source, target); // 移动最大的圆盘 hanoi(n-1, auxiliary, source, target); // 递归调用步骤3 } int main() { int n; printf("Enter the number of disks: "); scanf("%d", &n); hanoi(n, 'A', 'B', 'C'); // 调用递归函数 return 0; } ``` 通过上述C语言代码,我们可以递归地解决Hanoi问题,并输出每一步的移动方式。这个递归方法的时间复杂度是O(2^n),因为每个圆盘都要移动2^n次。但是由于递归的特性,它的空间复杂度是O(n),因为每次递归调用时需要保存函数的局部变量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值