10月8日 c语言 递归法 解hanoi

#include<stdio.h>
int main()
{
void hanoi(int n,char one,char two,char three);
int m ;
printf("please input the numer of diskes:");
scanf("%d",&m);
printf("the step to move %d dicskes:\n",m);
hanoi(m,'A','B','C');
}
 void hanoi(int n,char one,char two,char three)
 {
void move(char x,char y);
if(n==1)
move(one,three);
else 
{
hanoi(n-1,one,three,two);
move(one,three);
hanoi(n-1,two,one,three);
}
 }
 
 void move(char x,char y)
  {
 printf("%c-->%c\n",x,y);
  }



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hanoi塔是一个经典的递归问题,它可以用C语言来实现。Hanoi塔问题的规则是,有三根柱子A、B、C,以及n个不同大小的圆盘,初始时,所有圆盘都放在柱子A上,目标是将所有圆盘从A柱子移动到C柱子上,每次只能移动一个圆盘,并且大的圆盘不能放在小的圆盘上面。 要Hanoi塔问题,可以使用递归的方递归的思想是将大问题分成一个个小问题来决,然后通过组合小问题的决整个问题。 在这个问题,我们可以将n个圆盘的移动分为三个步骤: 1. 将n-1个圆盘从A柱子移动到B柱子上; 2. 将最大的一个圆盘从A柱子移动到C柱子上; 3. 将n-1个圆盘从B柱子移动到C柱子上。 这样,问题就被分成了三个小问题,而这三个小问题与原问题的规模相比减小了,因此可以使用递归的方决。 具体的C语言递归代码如下: ```c void hanoi(int n, char source, char auxiliary, char target) { if (n == 1) { // 只有一个圆盘时,直接从source柱子移动到target柱子上 printf("Move disk from %c to %c\n", source, target); return; } hanoi(n-1, source, target, auxiliary); // 递归调用步骤1 printf("Move disk from %c to %c\n", source, target); // 移动最大的圆盘 hanoi(n-1, auxiliary, source, target); // 递归调用步骤3 } int main() { int n; printf("Enter the number of disks: "); scanf("%d", &n); hanoi(n, 'A', 'B', 'C'); // 调用递归函数 return 0; } ``` 通过上述C语言代码,我们可以递归Hanoi塔问题,并输出每一步的移动方式。这个递归的时间复杂度是O(2^n),因为每个圆盘都要移动2^n次。但是由于递归的特性,它的空间复杂度是O(n),因为每次递归调用时需要保存函数的局部变量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值