很久没去接触c语言了,今天翻了翻c语言的书,偶然间看到了大一时让我郁闷了很久的汉诺塔问题,又重新推理了一遍,汉诺塔的实现采用递归算法,涉及到数据结构中的栈的知识。下面是c实现汉诺塔的源码。程序只是实现了文字信息,即用文字描述了圆盘的移动过程,并未真正实现圆盘的移动,该程序难度并不大,要了解递归的原理和方法中参数值的变化。
# include <stdio.h>
void hannuota(int n,char one,char two,char three);
void move(char x,char y);
int main(void) {
int n;
printf("please input a integer number:");
scanf("%d",&n);
if(n > 10 || n < 0) {
printf("请输入一个0~10范围内的整数!!");
return 0;
}
hannuota(n,'A','B','C');
return 0;
}
void hannuota(int n,char one,char two,char three) {
if(n == 1) {
move(one,three); //<1>
}
else {
hannuota((n-1),one,three,two); //<2>
move(one,three); //<3>
hannuota((n-1),two,one,three); //<4>
}
}
void move(char x,char y) {
printf("%c ----> %c\n",x,y);
}
为了避免运行需要很长的时间,程序限制了输入的整数大小为0-10,以下是程序执行的顺序:(为了篇幅,假设n的值是3)
main方法运行到hannuota(n,'A','B','C')时;该方法里的参数为hannuota(3,'A','B','C');
1、第一部分:把A柱中的n-1个圆盘借助C柱移动到B柱
此时执行hannuota方法,因为n=3>1,因此此时递归执行hantuona方法,此时方法参数为hannuota(2,'A','C','B'),(注意此时hannuota方法的参数改变了,C和B值互换);因为n=2>1,继续递归调用hannuota(1,'A','B','C');(此时hannuota方法的参数改变了,C和B值互换);因为n=1,所以执行move方法,打印出A-->C;
返回n=2时程序未执行完的部分,即执行标志为<3>的move方法,因为此时n=1,打印出A-->B,
继续执行标志为<4>的hannuota((n-1),two,one,three)部分,此时参数为hannuota(1,'C','A','B'); 此时n=1,打印出C-->B。到此刻位置标志为<2>部分的 hannuota((n-1),one,three,two)程序执行完毕。
2、第二部分:把A柱的第n个圆盘移动到C盘
此时直接执行标注为<3>部分的程序move(one,three); 此时打印出A-->C;
3、第三部分:把B柱上的n-1个圆盘借助A移动到C柱
此时执行标志为<4>部分的hannuota((n-1),two,one,three),此时参数为hannuota(2,'B','A','C');
因为n=2>1,执行标志为<2>的代码,此时方法参数为hannuota(1,'B','C','A');因为此时n=1,执行标志为<1>的代码,打印出B-->A;此时,标志为<2>的程序执行完毕,one,two,three的值分别为one=B,two=A,three=C;
继续执行标志<3>的程序move(one,three); 打印出B-->C; 继续执行至标志<4>的代码hannuota((n-1),two,one,three),参数为hannuota(1'A','B','C'),因此n=1,执行标志<1>的代码,打印出A-->C;
到此为止,程序执行完毕。
程序执行结果如下:
A ----> C
A ----> B
C ----> B
A ----> C
B ----> A
B ----> C
A ----> C
汉诺塔问题主要分为以上三个部分,程序中用到了递归算法,递归要用到栈的知识,就是进栈和出栈,每到递归调用一个系统的子系统时,都会为子系统分配内存单元,把正被调用的子系统压入栈顶,按照先进后出的规则,执行完后就弹出栈,释放为其分配的内存单元。然后继续执行栈中的其他部分,直到整个程序执行完毕。
分享到:
相关推荐
c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序c语言实现的汉诺塔演示程序...
本项目中的“C语言实现的汉诺塔演示程序”就是一个使用C语言编写的汉诺塔问题解决方案。它可能包括以下几个方面: 1. **函数定义**:程序通常会包含一个或多个函数,如`hanoi`,用于实现汉诺塔的递归逻辑。这个函数...
C语言实现汉诺塔的代码通常采用递归方法。以下是一个简单的C语言程序实现: ```c #include void hanoi(int n, char from_rod, char aux_rod, char to_rod) { if (n >= 1) { // 将n-1个圆盘从'from_rod'移到(aux...
采用C语言编写汉诺塔,运用递归的方法实现汉诺塔问题。
汉诺塔问题C语言实现
总结来说,"C语言编写汉诺塔程序"是一个展示递归算法的经典实例,通过理解并实现这样的程序,我们可以深入学习递归思想,提高逻辑分析能力,这对于计算机科学的学习和发展至关重要。这个压缩包中的“汉诺塔(源码)...
用C语言实现汉诺塔(hanoi)递归问题,适于初学者
C语言实现汉诺塔,选择要实现的汉诺塔的阶数,程序将显示此阶汉诺塔的解
C语言汉诺塔程序
《数据结构 严蔚敏 C语言版 汉诺塔》是计算机科学领域经典的学习资料,其中涵盖了数据结构、算法以及C语言编程的基础知识。严蔚敏教授的教材以其严谨和深入浅出著称,是许多学生和程序员入门数据结构的首选教材。...
汉诺塔 c语言编写的汉诺塔程序,C语言初学者必会
这是个汉诺塔程序,在调试的时候,输入的数字最好不要大于15,因为每大一个数 所得的结果的步骤都会多一倍。如果你有耐心等待结果的话除外。汉诺塔是在欧洲 流行的一种游戏,有a,b,c三个竿。a竿上有若干个由大到小的...
在C语言中实现汉诺塔问题,主要涉及以下几个知识点: 1. **函数定义**:首先,我们需要定义一个函数来执行汉诺塔的操作。这个函数通常被称为`hanoi`,它接受三个参数,分别代表起始柱、目标柱和辅助柱。 2. **递归...
利用c语言编写汉诺塔程序,适用于c语言初学者,对于c语言学习有很大帮助
c语言实现的汉诺塔演示程序 汉诺塔(Tower of Hanoi),又称河内塔。源自印度古老传说的一个游戏,大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把...
C语言实现汉诺塔、递归。初学者,谢谢
C语言实现汉诺塔时,通常会使用递归函数来表示这些步骤。代码中可能包含一个主函数,负责调用递归函数并初始化参数,以及一个递归函数,实现上述的移动逻辑。递归函数内部的逻辑将根据实际情况进行优化,例如通过...
总的来说,这个C语言程序通过递归实现了汉诺塔问题的解决方案,展示了递归算法在解决复杂问题时的强大能力。递归的关键在于每个子问题都与原问题具有相同的结构,而汉诺塔问题恰好满足这一条件。通过分解问题并不断...
### 汉诺塔C语言实现详解 #### 一、汉诺塔问题背景与规则 汉诺塔(Hanoi Tower)问题是一个经典的递归问题,起源于一个古老的传说。传说中,印度的一个寺庙里有一组梵塔,由三个塔座(A、B、C)组成,其中A座上放...