代码改变世界

Tower of hanoi问题学习

  youxin  阅读(359)  评论(0编辑  收藏  举报

 hanoi问题描述如下:三根杠,a,b,c,a盘上有n个盘子,盘的尺寸由下到上依次变小要把n个盘子由a杆借助c杆移动到b杆,要求有两条:

1,依次只能移动一个盘
2,不允许大盘放在小盘上面
 
用递归解题方法如下:

程序如下:

复制代码
#include<stdio.h>
void hanoi(int n,char a,char b,char c);
int main()
{
int n;
printf("请输入盘子的个数\n");
scanf("%d",&n);
hanoi(n,'a','b','c');

}

void hanoi(int n,char a,char b ,char c)
{
if(n>0)
{

hanoi(n-1,a,c,b);
printf("move disc %d from pile %c to %c\n",n,a,b);
hanoi(n-1,c,b,a);
}
}
复制代码



 

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示