关于C语言解决汉诺塔(hanoi)问题
C语言解决汉诺塔问题
汉诺塔是典型的递归调用问题:
hanoi简介:印度教的主神梵天在创造世界的时候,在其中一根针上从下到上地穿好了由大到小的64片金片,这就是所谓的汉诺塔。不论白天黑夜,总有一个僧侣在按照下面的法则移动这些金片:一次只移动一片,不管在哪根针上,小片必须在大片上面。僧侣们预言,当所有的金片都从梵天穿好的那根针上移到另外一根针上时,世界就将在一声霹雳中消灭,而梵塔、庙宇和众生也都将同归于尽。

--图片来源于百度百科
A,B,C三个柱子,当A柱子上只有一个盘子时直接将该盘子从A柱子移到C柱子上,当A柱子上有n个盘子时,先借助C柱子将n-1移到B柱子上,然后把最后一个从A柱子移到C柱子上,其次把n-1个盘子借助A柱子从B柱子移到C柱子,那么就是三步。
大事化小,小事化了:分三步走
1.把A柱子上的n-1个盘子借助C柱子移到B柱子上
2.然后把最后一个盘子从A柱子直接移到C柱子
3.再然后把B柱子上的n-1个盘子借助A柱子移到C柱子上
代码如下:
#include<stdio.h>
void hanoi(int n,char a,char b ,char c); //声明hanoi函数
int main()
{
int n;
printf("enter n:");
scanf("%d",&n);
hanoi(n,'A','B','C'); } void hanoi(int n,char a,char b ,char c) //n代表有多少个盘子,a、b、c代表各个柱子
{
if(n == 1 || n == 0)
{
printf("%c -- %c\n",a,c); //要是剩下最后一个盘子 就直接从a移到c }else
{
hanoi(n-1,a,c,b); //借助c 把n-1个盘子从a移到b
printf("%c -- %c\n",x,z);//直接把a移到c
hanoi(n-1,b,a,c);//借助a 把n-1个盘子从b移到c
}
}
关于C语言解决汉诺塔(hanoi)问题的更多相关文章
- C语言解决汉诺塔问题!
		很难受,看了很多资料才明白..... 对这个问题分析,发现思路如下:有n个黄金盘,要先把n-1个弄到B柱上,再把第n个弄到C柱上,然后把n-1个借助A柱弄到C柱上. 实现的函数如下: void f(i ... 
- 编程:递归编程解决汉诺塔问题(用java实现)
		Answer: //Li Cuiyun,October 14,2016. //用递归方法编程解决汉诺塔问题 package tutorial_3_5; import java.util.*; publ ... 
- 汉诺塔hanoi
		问题描述: 有一个梵塔,塔内有三个座A.B.C,A座上有诺干个盘子,盘子大小不等,大的在下,小的在上(如图). 把这些个盘子从A座移到C座,中间可以借用B座但每次只能允许移动一个盘子,并且在移动过程中 ... 
- 用C语言实现汉诺塔自动递归演示程序
		用C语言实现汉诺塔自动递归演示程序 程序实现效果 1.变界面大小依照输入递归数改变. 2.汉诺塔自动移动演示. 3.采用gotoxy实现流畅刷新. 4.保留文字显示递归流程 程序展示及实现 githu ... 
- 用递归方法解决汉诺塔问题(Recursion Hanoi Tower Python)
		汉诺塔问题源于印度的一个古老传说:梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.梵天命令婆罗门把圆盘按大小顺序重新摆放在另一根柱子上,并且规定小圆盘上不能放 ... 
- C语言:使用递归解决汉诺塔问题。
		//汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命令婆罗门把圆盘从下面开始按大小 ... 
- C#递归解决汉诺塔问题(Hanoi)
		using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace MyExamp ... 
- 【C语言】汉诺塔问题
		之前遇见这个问题,非常费劲地理解了,并写出代码,然后过段时间,再遇见这个问题,又卡住了,如此反反复复两三次,才发现自己对递归的理解依然很肤浅.今天无聊,重温<算法:c语言实现>一书,又遇见 ... 
- 【学习】Python解决汉诺塔问题
		参考文章:http://www.cnblogs.com/dmego/p/5965835.html 一句话:学程序不是目的,理解就好:写代码也不是必然,省事最好:拿也好,查也好,解决问题就好! ... 
随机推荐
- NGK数字增益平台的算力是什么?
			今年的币价回暖带来了新一轮的"信仰充值",部分投资者对比特币的兴趣从购买向更源头的算力转移.随着比特币开采数量逐渐减少,全网算力一直在增加,算力难度也是越来越高.同时在算力行业中竞 ... 
- 从崩溃的选课系统,论为什么更安全的 HTTPS 协议没有被全面采用
			尽人事,听天命.博主东南大学研究生在读,热爱健身和篮球,正在为两年后的秋招准备中,乐于分享技术相关的所见所得,关注公众号 @ 飞天小牛肉,第一时间获取文章更新,成长的路上我们一起进步 本文已收录于 C ... 
- css选择器,过滤筛选
			$('.required:not(.final_price)').each(function() { if (!$(this).val()) { error_count ++; if ($(this) ... 
- 1090 Highest Price in Supply Chain——PAT甲级真题
			1090 Highest Price in Supply Chain A supply chain is a network of retailers(零售商), distributors(经销商), ... 
- 【重磅】iNeuOS工业互联平台,系统集成业务模型和WEB组态视图建模集成3D模型
			目 录 1. 概述... 1 2. 平台演示... 2 3. 系统集成业务模型... 2 4. WEB组态视图建模集成3D模型... 3 5. ... 
- Hexo一键部署到阿里云OSS并设置浏览器缓存
			自建博客地址:https://bytelife.net,欢迎访问! 本文为博客自动同步文章,为了更好的阅读体验,建议您移步至我的博客 本文作者: Jeffrey 本文链接: https://bytel ... 
- 番外----python入门----关于pycharm
			江湖上有句话叫 "武林至尊,宝刀屠龙,号令天下,莫敢不从,倚天不出,谁与争锋". 今天,我们就来介绍一下,python编程界的"屠龙刀",pycharm. 一. ... 
- Asp.Net Core WebAPI中启用XML格式数据支持
			因为XML是一种非常常用的数据格式,所以Asp.Net core提供了非常便利的方式来添加对XML格式的支持 只需要在IOC注册Controller服务的后面跟上.AddXmlDataContract ... 
- Chrome OS超便捷安装指南
			Chrome OS是一款Google开发的基于PC的操作系统. Google Chrome OS是一款基于Linux的开源操作系统.Google在自己的官方博客表示,初期,这一操作系统将定位于上网本. ... 
- there is nothing(i春秋CTF题解)
			(1)打开页面,显示为:there is nothing (2)抓包发现提示 (3)hint:ip,Large internal network 意为最大的内网网段IP,hint: ip,Larg ... 
