#include <stdio.h>
void moveOneDisk(int from, int to) {
printf("杭%dから杭%dに移動\n", from
, to
); }
void moveDisks(int from, int to, int n) {
if (n == 1) {
moveOneDisk(from, to);
} else {
int anotherPole = 6 - (from + to); // 1+2+3=6 を利用
moveDisks(from, anotherPole, n - 1); // 上からn-1枚を別の杭へ
moveOneDisk(from, to); // 一番下の円盤を目的地へ
moveDisks(anotherPole, to, n - 1); // 別の杭にあるn-1枚を目的地へ
}
}
int main(void) {
int n = 5;
printf("%d枚の円盤を杭1から杭3に移動させる手順は以下のとおり:\n", n
); moveDisks(1, 3, n);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+Cgp2b2lkIG1vdmVPbmVEaXNrKGludCBmcm9tLCBpbnQgdG8pIHsKICAgIHByaW50Zigi5p2tJWTjgYvjgonmna0lZOOBq+enu+WLlVxuIiwgZnJvbSwgdG8pOwp9Cgp2b2lkIG1vdmVEaXNrcyhpbnQgZnJvbSwgaW50IHRvLCBpbnQgbikgewogICAgaWYgKG4gPT0gMSkgewogICAgICAgIG1vdmVPbmVEaXNrKGZyb20sIHRvKTsKICAgIH0gZWxzZSB7CiAgICAgICAgaW50IGFub3RoZXJQb2xlID0gNiAtIChmcm9tICsgdG8pOyAvLyAxKzIrMz02IOOCkuWIqeeUqAogICAgICAgIG1vdmVEaXNrcyhmcm9tLCBhbm90aGVyUG9sZSwgbiAtIDEpOyAgLy8g5LiK44GL44KJbi0x5p6a44KS5Yil44Gu5p2t44G4CiAgICAgICAgbW92ZU9uZURpc2soZnJvbSwgdG8pOyAgICAgICAgICAgICAgIC8vIOS4gOeVquS4i+OBruWGhuebpOOCkuebrueahOWcsOOBuAogICAgICAgIG1vdmVEaXNrcyhhbm90aGVyUG9sZSwgdG8sIG4gLSAxKTsgICAvLyDliKXjga7mna3jgavjgYLjgotuLTHmnprjgpLnm67nmoTlnLDjgbgKICAgIH0KfQoKaW50IG1haW4odm9pZCkgewogICAgaW50IG4gPSA1OwogICAgcHJpbnRmKCIlZOaemuOBruWGhuebpOOCkuadrTHjgYvjgonmna0z44Gr56e75YuV44GV44Gb44KL5omL6aCG44Gv5Lul5LiL44Gu44Go44GK44KKOlxuIiwgbik7CiAgICBtb3ZlRGlza3MoMSwgMywgbik7CiAgICByZXR1cm4gMDsKfQo=