하노이탑
IT 위키
시간복잡도 : O(2^n)
출처 : [1]
// PSEUDO CODE FROM A TO B
void Hanoi(int N, int A, int TO, int B) {
if (N == 1) {
print(A->B);
return;
}
Hanoi(N - 1, A, B, TO);
print(A -> B);
Hanoi(N - 1, TO, A, B);
/*
모르면 외우자...
N : 원판의 개수
A : 출발지
B : 옮기기 위해 이동해야 장소
C : 목적지
*/
void Hanoi(int N, int A, int B, int C) {
// 이동할 원반의 수가 1개
if (N == 1) {
print(A + " " + C + "\n");
return;
}
// A -> B(N-1개)
Hanoi(N - 1, A, C, B);
// A->C(1개)
print(A + " " + C + "\n");
// B->C(N-1개)
Hanoi(N - 1, B, A, C);
}
출처 : [2]