NKOJ1078 汉诺塔
输入格式
一行,只有一个整数n,表示最初A柱子上的金盘数(n<=23)
输出格式
若干行,每行两个大写字母,中间用TO连接,表示盘子移动的方向
最后一行,一个整数,表示最小的步数
样例输入
3
样例输出
A TO C
A TO B
C TO B
A TO C
B TO A
B TO C
A TO C
7
提示
注意:TO的左右两边都有空格
#include<cstdio>
using namespace std;
#define move(a,b) putchar(a),putchar(' '),putchar('T'),putchar('O'),putchar(' '),putchar(b),putchar(10)
inline void h(int n,char a,char b,char c)
{
if(n==1) move(a,c);
else
{
h(n-1,a,c,b);
move(a,c);
h(n-1,b,a,c);
}
}
int main()
{
int n;scanf("%d",&n);
h(n,'A','B','C');
printf("%d",(1<<n)-1);
}