C语言:汉诺塔-函数调用

代码注释很详细了

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>

int move(int N, char A, char B, char C) //N表示当前移动的几号盘
{
	if (N == 1)
	{
		printf("圆盘%d,从%c移到%c!\n", N, A, C);
	}
	else
	{
		//当圆盘数量超过1时,需要将N-1个圆盘放在柱子B,再将最大的圆盘第N个圆盘放在柱子C
		move(N - 1, A, C, B); //将N-1个圆盘放在柱子B
		printf("圆盘%d,从%c移到%c!\n", N, A, C); 
		move(N - 1, B, C, A); //将N-1个圆盘放在柱子A
	}
}

int main()
{
	//汉诺塔算法——C语言递归实现

	int N; //圆盘数量
	char A = 'A', B = 'B', C = 'C'; // 柱子,数量是3个
	scanf("%d", &N);

	//初始条件下,圆盘全部放在柱子A,目标是将圆盘全部移到柱子C

	printf("%d个圆盘\n", N);
	move(N, A, B, C); //函数参数一定要初始化


	return 0;
}

运行结果:

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值