题目:http://bailian.openjudge.cn/practice/4147?lang=en_US
Code:
#include<bits/stdc++.h>
using namespace std;
const int INF = 0x3f3f3f3f;
const int MAXN = 1e5 + 7;
int n;
char a, b, c;
void Move_One(int n, char a, char c)
{
cout << n << ":" << a << "->" << c << endl; //把n号从a移动到c
}
void deal(int n, char a, char b, char c)
{
if(n == 1) Move_One(n, a, c);
else
{
deal(n - 1, a, c, b); //把前n - 1 个从a借助c移动到b
Move_One(n, a, c);
deal(n - 1, b, a, c);
}
return ;
}
int main()
{
cin >> n >> a >> b >> c;
deal(n, a, b, c);
return 0;
}
汉诺塔问题C++实现
本文介绍了一个经典的递归问题——汉诺塔问题,并使用C++编程语言提供了详细的解决方案。通过递归调用的方式,文章展示了如何将n个盘子从初始柱子A借助中间柱子B移动到目标柱子C的过程。
2584

被折叠的 条评论
为什么被折叠?



