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

与手动分析无异

相关推荐
Severus_black1 分钟前
C实现双向链表和相关函数!巨详细!
c语言·数据结构·链表·list
菠萝地亚狂想曲1 小时前
FreeRTOS heap4
c语言·stm32·嵌入式开发
计算机安禾1 小时前
【数据结构与算法】第40篇:图论(四):最短路径——Dijkstra算法与Floyd算法
c语言·数据结构·算法·排序算法·哈希算法·图论·visual studio
lcj25112 小时前
【C语言】自定义类型1:结构体
c语言·开发语言·算法
cmpxr_2 小时前
【C】隐式类型转换
c语言·c++·算法
泛凡(Linyongui)2 小时前
PY32F002B实践之三--宠物腹背理疗仪项目功能代码分析说明
c语言·keil·32位单片机·腹背理疗仪项目实践·普苒py32
智者知已应修善业2 小时前
【51单片机独立按键控制数码管动态显示和LED间隔闪烁并清零】2023-5-28
c语言·经验分享·笔记·算法·51单片机
水云桐程序员2 小时前
用C语言开发单片机项目的工作思路
c语言·开发语言·单片机
她说彩礼65万2 小时前
C语言 指针运算
c语言·数据结构·算法
weixin_4460235612 小时前
C语言:面向过程、应用底层开发、跨平台的通用程序设计语言
c语言·跨平台·数据类型·底层开发·面向过程