汉诺塔(代码记录+注释)
Posted 0526yao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汉诺塔(代码记录+注释)相关的知识,希望对你有一定的参考价值。
//汉诺塔问题 //输出移动的步骤 #include <stdio.h> //记录步数 int i = 1; //n 第几号盘移动, from 移动塔 to 目标塔 void move(int n, char from,char to){ printf("第%d次移动第%d号盘: %c----->%c ",i++,n,from,to); } void hanoi(int n,char from,char mid,char to){ if(n==1){ move(n,from,to);//只有一个盘子是直接将初塔上的盘子移动到目的地 }else{ hanoi(n-1,from, to, mid);//先将初始塔的前n-1个盘子借助目的塔移动到借用塔上 move(n,from,to); //将剩下的一个盘子移动到目的塔上 hanoi(n-1,mid, from,to);//最后将借用塔上的n-1个盘子移动到目的塔上 } } int main(){ printf("请输入盘子的个数: "); int n; scanf("%d",&n); char x=‘A‘,y=‘B‘,z=‘C‘; printf("盘子移动情况如下: "); hanoi(n,x,y,z); return 0 ; }
以上是关于汉诺塔(代码记录+注释)的主要内容,如果未能解决你的问题,请参考以下文章