算法思考--------汉诺塔c语言实现-------递归
2014-03-18 22:14
302 查看
递归:首先A上有n个圆盘,只需现将n-1个圆盘由A借助C移动到B,再将A上第n个圆盘由A直接移到C,再将B上的n-1个圆盘移到C上即可,而要想移动n-1 个圆盘,就要先移动n-2个圆盘,依次向下,便是递归。
但每次递归都要向栈中压入函数的返回信息等,会占很多内存,所以用递归算法实现虽然很简洁,但效率很低。
#include<stdio.h>
void hannuota(int,char,char,char);
int main()
{
int n;
printf("please input an number\n");
scanf("%d",&n);
hannuota(n,'a','b','c');
return 0;
}
void hannuota(int n,char A,char B,char C) //把第n个圆盘借助B从A移到C
{
if(1==n)
printf("直接将编号为%d的圆盘从%c移到%c\n",n,A,C);
else
{
hannuota(n-1,A,C,B);
printf("直接将编号为%d的圆盘从%c移到%c\n",n,A,C);
hannuota(n-1,B,A,C);
}
}
相关文章推荐
- C语言经典算法(十)——递归实现汉诺塔
- 【数据结构与算法】汉诺塔算法——C语言递归实现
- 第三篇:汉诺塔算法——C语言递归实现
- 【数据结构与算法】汉诺塔算法——C语言递归实现
- c语言,python实现汉诺塔,关于闭包的思考
- C语言实现二叉树的常用的算法(递归与非递归实现遍历)
- poj算法-使用C语言在VC++6.0实现poj1753(递归枚举)
- 算法----汉诺塔的递归实现
- C语言实现快排、归并排序、快排改进算法的递归和非递归算法
- 汉诺塔递归的c语言实现(递归)
- 【Fiay】【Java】汉诺塔算法 递归实现
- [算法]简单的背包问题递归解法,C语言实现
- 汉洛塔递归实现的思考(C语言)
- C语言实现Hanoi(汉诺塔)问题的递归求解
- 【数据结构与算法】(五) c 语言递归与汉诺塔实现
- [算法]数据结构算法背包问题解法之递归解法,C语言实现
- 【算法】二叉树的递归遍历C语言实现
- 【数据结构与算法】汉诺塔算法——java递归实现
- 大学常见算法的java实现及思考-汉诺塔问题
- 【经典问题】汉诺塔(递归、C语言实现)