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

与手动分析无异

相关推荐
细嗅蔷薇@2 小时前
C语言在键盘上输入一个3行3列矩阵的各个元素的值(值为整数),然后输出主对角线元素的积,并在fun()函数中输出。
c语言·算法·矩阵
吻等离子2 小时前
Linux ARM 平台 C 语言操作 Excel 文件的常用库与工具汇总(支持 xls 和 xlsx)
linux·c语言·arm开发
mftang2 小时前
C 标准库 <time.h> 函数详解
c语言·开发语言
菜还不练就废了4 小时前
7.25 C/C++蓝桥杯 |排序算法【下】
c语言·c++·排序算法
程序员编程指南5 小时前
Qt 移动应用性能优化策略
c语言·开发语言·c++·qt·性能优化
程序员编程指南7 小时前
Qt 移动应用常见问题与解决方案
c语言·开发语言·c++·qt
野原鑫之祝11 小时前
嵌入式开发学习———Linux环境下数据结构学习(五)
linux·c语言·数据结构·学习·vim·排序算法·嵌入式
知柠12 小时前
C语言-指针
c语言·开发语言
晨非辰12 小时前
#C语言——学习攻略:深挖指针路线(四续)——函数指针数组--转移表
c语言·开发语言·经验分享·学习·visual studio
草莓熊Lotso12 小时前
【数据结构初阶】--二叉树(五)
c语言·数据结构·经验分享·笔记·其他