C语言程序设计第四版(何钦铭、颜晖)第十章函数与程序设计之汉诺塔问题

汉诺(Hanoi)塔问题。传说印度古代某寺庙中有一个梵塔,塔内有3个座A、B和C,座A上放着64个大小不等的盘,其中大盘在下,小盘在上。有一个和尚想把这64个盘从座A搬到座B,但一次只能搬一个盘,搬动的盘只允许放在其他两个座上,且大盘不能压在小盘上。现要求用程序模拟该过程,并输出搬动步骤。

复制代码
#include<stdio.h>
void hanoi(int n,char a,char b,char c);
int main()
{
    int n;
    printf("Input the number of disk:\n");
    scanf("%d",&n);
    printf("The steps of %d disk are:\n");
    hanoi(n,'a','b','c');
	return 0;
}
void hanoi(int n,char a,char b,char c){
    if(n==1)printf("%c-->%c\n",a,b);
    else{
        hanoi(n-1,a,c,b);
        printf("%c-->%c\n",a,b);
        hanoi(n-1,c,b,a);
    }
}

输入样例:3

输出结果:

Input the number of disk:

The steps of 0 disk are:

a-->b

a-->c

b-->c

a-->b

c-->a

c-->b

a-->b

相关推荐
郝学胜-神的一滴23 分钟前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫23 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
爱编码的小八嘎24 分钟前
C语言完美演绎7-7
c语言
来日可期131425 分钟前
C/C++ 反常识记录(1)—— 那些容易踩坑的语法细节
c语言·开发语言·c++
计算机安禾28 分钟前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
Q741_14731 分钟前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划
实心儿儿32 分钟前
C++ —— C++11(2)
开发语言·c++
加油JIAX33 分钟前
C++11特性
c++
wfbcg39 分钟前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展
Wect43 分钟前
LeetCode 149. 直线上最多的点数:题解深度剖析
前端·算法·typescript