C 练习实例98-汉诺塔(完结撒花)

递归

cpp 复制代码
#include <stdio.h>
int sumN(int n)
{
	if( n == 1 )
		return 1;
	else
		return sumN(n-1)+n;
}
int main()
{
	printf("数列n的前%d项和为: %d",100,sumN(100));
	return 0;
}
bash 复制代码
数列n的前100项和为: 5050

汉诺塔

人为分析

A B C 3个柱子

当只有1个盘子时:

A --> C

当有2个盘子时:

A --> B

A --> C

B --> C

当有3个盘子时:

A --> C

A --> B

C --> B

A --> C

B --> A

B --> C

A --> C

思路分析

假设总共需要移动n个盘子

1.将A柱上的n-1个盘子借助C柱移向B柱

2.将A柱上仅剩的最后一个盘子移向C柱

3.将B柱上的n-1个盘子借助A柱移向C柱

具体怎么挪的,大可不必费神!

代码实现

cpp 复制代码
#include <stdio.h>
void move(int n, char A, char B, char C)
{
	if(n==1){
		printf("%c --> %c\n", A, C);//只有一个盘子的情况
	}else{
		move(n-1, A, C, B);
		printf("%c --> %c\n", A, C);
		move(n-1, B, A, C);
	}
}
int main()
{
	move(2,'A','B','C');
	return 0;
}

参数为2运行结果

bash 复制代码
A --> B
A --> C
B --> C

参数为3运行结果

bash 复制代码
A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C

与手动分析无异

相关推荐
ytttr87321 分钟前
OPC UA 协议栈 C 语言实现
c语言·开发语言·mfc
song50122 分钟前
Ascend C 算子开发:从入门到上手
c语言·开发语言·图像处理·人工智能·分布式·flutter·交互
小a杰.42 分钟前
Ascend C编程语言进阶:高性能算子开发技巧
android·c语言·开发语言
小a杰.2 小时前
Ascend C算子开发实战 - 从零开始写算子
c语言·开发语言
我还记得那天7 小时前
数组的2个应用举例
c语言·开发语言·二分查找·数组
学困昇8 小时前
Linux IPC 详解:匿名管道、命名管道、共享内存与信号量
linux·运维·服务器·c语言·c++·人工智能
『昊纸』℃9 小时前
作为小白,C语言如何从零开始呢
c语言·ide·学习·编程·教材
iCxhust9 小时前
个人计算机的起点,INTEL 8088
c语言·单片机·嵌入式硬件·微机原理·8088单板机
聆风吟º9 小时前
深入理解C语言 islower 函数详解:判断字符是否为小写字母
c语言·开发语言·库函数·字符处理·islower
冉卓电子10 小时前
MPC5604B/C MC_RGM 复位模块全解
c语言·开发语言·单片机·嵌入式硬件