微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

【数据结构】递归算法—汉诺塔

汉诺塔的问题,也是一个经典的递归算法问题。


下面是自己总结的一张整体流程图。



下面是代码代码虽简单,但理解其内部运行原理很重要。

//======================================================================    
//    
//        copyright (C) 2014-2015 SCott        
//        All rights reserved    
//    
//        filename: HanNuoTa.c  
//        description: a demo to display HanNuoTa  
//    
//        created by SCott at  02/10/2015   
//        http://blog.csdn.net/scottly1  
//    
//====================================================================== 

#include <stdio.h>

void HanNuoTa(int n,char a,char b,char c)
{
	if( n < 1 )
		return ;	
	HanNuoTa(n-1,a,c,b);
	printf("把第%d盘子通过%c移到%c\n",n,c);
	HanNuoTa(n-1,b,c);
}

int main()
{
	int num;

	printf("Input The Num you want to create:");
	scanf("%d",&num);

	HanNuoTa(num,'A','B','C');

	return 0;
}

运行结果:


如果对电脑的算法有怀疑,大家可以自己动手算算,看看它的方法是不是最优的。


原创文章,转载请著名出处:http://blog.csdn.net/scottly1/article/details/43705291

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐