C语言案例——汉诺塔问题

题目描述

  1. 每次只能移动一个圆盘
  2. 大的圆盘不能放在小的圆盘上面
  3. 可以使用一根额外的柱子作为辅助

默认三个柱子,盘子数量为N,

解法思路

设A\B\C三个柱子

将A柱上的n个盘子挪到C柱上,只有一个盘子的时候,只需从A挪到C。如果盘子的数量大于两个,将n-1个盘子从A挪到B,再将最下面的那个盘子从A挪到C 再将B上的n-1个盘子挪到C上 ......

解法代码

cs 复制代码
#include <stdio.h>  

void move(int num, char x, char y)
{
    printf("第%d个盘子,%c--->%c\n", num, x, y);
}

void hannot(int num, char A, char B, char C)
{
    if (num == 1)
    {
        move(num, A, C);
    }
    else
    {
        hannot(num - 1, A, C, B);
        move(num, A, C);
        hannot(num - 1, B, A, C);
    }
}

int main()
{
    int num = 0; // 盘子数量  
    printf("请输入盘子的数量: ");
    scanf("%d", &num);
    hannot(num, 'A', 'B', 'C'); // A起始位置,B中转位置,C目标位置  
    return 0;
}

运行结果

请输入盘子的数量:

3

第1个盘子,A--->C

第2个盘子,A--->B

第1个盘子,C--->B

第3个盘子,A--->C

第1个盘子,B--->A

第2个盘子,B--->C

第1个盘子,A--->C

相关推荐
I Promise3418 小时前
C++ 单例模式超详细讲解
开发语言·c++·单例模式
wuweijianlove18 小时前
算法性能优化中的数据流重构与依赖消解的技术6
算法
Agent手记18 小时前
智能财务对账Agent如何设计?2026金融大模型Agent架构设计与实战指引
人工智能·算法·ai·金融
之歆18 小时前
Day17_JavaScript高级核心垃圾回收执行上下文闭包完全指南(上)
开发语言·javascript·ecmascript
Emerson_202618 小时前
stack,queue,list的区别和联系
数据结构·c++·list·queue·stack
xu_wenming18 小时前
zephyr从会用走向精通
c语言·嵌入式硬件·物联网
weixin_5500831518 小时前
基于Python的豆瓣电影数据爬取与可视化分析
开发语言·python
计算机安禾18 小时前
【算法分析与设计】第5篇:最大子数组问题:分治与线性扫描的对比分析
算法
xyq202418 小时前
jQuery Mobile Data 属性详解
开发语言
YOLO数据集集合18 小时前
光伏板缺陷检测数据集|红外可见光双模态|无人机光伏巡检|智慧电网光伏识别数据集
开发语言·yolo·目标检测·无人机