数据结构 栈和递归 汉诺塔

汉诺塔
伪算法:
如果是一个盘子
直接将A柱子上的移到C//此时的A,C并不是A,C柱子,而是这两个参数所代表的柱子,下面同理
否则
先将A柱子上的n-1个盘中借助C移动到B
直接将A柱子上的盘子从A移到C
最后将B柱子上的n-1个盘子借助A移到C

通过递归将汉诺塔从n个盘的问题一步步变成1个盘子的问题,知道1个盘子怎么做就能推出2个盘,这样。。。。推出n-
1个盘子怎么做,就能得到n个盘子怎么做。

c++代码:

	#include <iostream>
	class Hannuota{
	public:
		char A;
		char B;
		char C;
		int n;
		
		Hannuota();
		void hannuotasuanfa(int n,char ,char,char);
	};

int main(){
	
	Hannuota ta;
	
	ta.hannuotasuanfa(ta.n,ta.A,ta.B,ta.C);
	
	return 0;
} 

void Hannuota::hannuotasuanfa(int n,char A,char B,char C){
	if(n==1)
		std::cout<<"将编号为"<<n<<"的盘子直接从"<<A<<"柱子移到"<<C<<"柱子\n";
	else{
		hannuotasuanfa(n-1,A,C,B);
		std::cout<<"将编号为"<<n<<"的盘子直接从"<<A<<"柱子移到"<<C<<"柱子\n";
		hannuotasuanfa(n-1,B,A,C);
	}
	return;	
}
Hannuota::Hannuota(){
	A='A';
	B='B';
	C='C';
	
	std::cout<<"请输入要移动的盘中的个数:";
	std::cin>>n; 
}

c代码:

#include <stdio.h>
void hannuota(int n,char x,char y,char z);
int main(){
	char ch1='A';
	char ch2='B';
	char ch3='C';
	int n;
	
	printf("请输入要移动的盘中的个数:");
	scanf("%d",&n);
	
	hannuota(n,'A','B','C');
	
	return 0;
} 

void hannuota(int n,char A,char B,char C){
	/*伪算法 
	如果是一个盘子
		直接将A柱子上的移到C//此时的A,C并不是A,C柱子,而是这两个参数所代表的柱子,下面同理 
	否则
		先将A柱子上的n-1个盘中借助C移动到B
		直接将A柱子上的盘子从A移到C
		最后将B柱子上的n-1个盘子借助A移到C 
	*/
	if(n==1)
		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);
	}
	return;	
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值