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

相关推荐
SuperByteMaster43 分钟前
keil 工程 .gitignore配置文件
c语言
超级码力6661 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind2 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F4 小时前
Problem - 2205D - Codeforces
算法
老花眼猫5 小时前
编制椭圆旋转绘图函数
c语言·经验分享·青少年编程·课程设计
智者知已应修善业5 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn5 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室6 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构