#include <stdio.h>
int Count=0;
void move(char x, int n, char z) {
printf("%2d. Move disk %d from %c to %c\n",++Count,n,x,z);
}
void hanoi (int n, char x, char y, char z) { // 算法3.5
// 将塔座x上按直径由小到大且至上而下编号为1至n的n个圆盘按规则搬到
// 塔座z上,y可用作辅助塔座。
// 搬动操作 move (x, n, z) 可定义为:
// (c是初值为0的全局变量,对搬动计数)
// printf("%i. Move disk %i from %c to %c\n", ++c, n, x, z);
if (n==1)
move(x, 1, z); //将编号为1的圆盘从x移到z
else {
hanoi(n-1,x,z,y);
move(x, n, z); //将编号为n的圆盘从x移到z
hanoi(n-1, y, x, z); //将y上编号为1至n-1的圆盘移到z,x作辅助塔
}
}
int main(){
int n;
while(scanf("%d", &n) != EOF){
Count = 0;
hanoi(n, 'X', 'Y', 'Z');
putchar('\n');
}
return 0;
}
/**************************************************************
Problem: 2146
User: admin
Language: C++
Result: Accepted
Time:14 ms
Memory:1144 kb
****************************************************************/