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

相关推荐
BothSavage1 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn1 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽3 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
郝学胜_神的一滴3 小时前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
先吃饱再说19 小时前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天19 小时前
C++ 基础入门完全指南
c++
黄敬峰21 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程