每天一道算法题-汉诺塔

汉诺塔问题,有三根棒为A、B、C。A棒上叠放着n个大小不等的盘,
依次叠加为大盘在下,小盘在下。要求把这n个盘移到C棒上,在移
动过程中可以借助B棒,每次只能移一个盘,并且在移动过程中必须保
持3根棒上的大盘在上,小盘在下。编写程序,并打印出移盘步骤。


/***************思路*************************************/
/*
当只有一个盘子的时候:直接将盘子从A移动到C
A -> C 

两个盘子的时候:
Step1. 把上面那个盘子,从A移动到B
A -> B
Step2. 将最大的盘子从A移动到C
A -> C
Step3. 把B上面的盘子,从B移动到C
B -> C

三个盘子的时候:
Step1. 利用两个盘子的算法,将上面两层盘子从A移动到B.====hanno(n - 1, a, c, b);
Step2. 将最大的盘子移动到C
step3. 利用两个盘子的算法,将B上面的盘子移动到C.====hanno(n - 1, b, a, c);

*/
#include<iostream>
using namespace std;

void hanno(int n, char a, char b, char c)
{
	if (n == 1)
	{
		cout << "将第" << n<< "号盘子从" << a << "移动到" << c << endl;
		return;
	}
	//将上面n-1个盘子从A移动到B
	hanno(n - 1, a, c, b);
	//将最下面一个盘子从A移动到C
	cout << "将第" << n << "号盘子从" << a << "移动到" << c << endl;
	//将B上面的n-1个盘子从B移动到C
	hanno(n - 1, b, a, c);
}
int main()
{
	hanno(2, 'a', 'b', 'c');
	system("pause");
}

转载于:https://www.cnblogs.com/readlearn/p/10806399.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值