Я хочу найти n-ю конфигурацию в решении проблемы Ханойских башен, учитывая количество дисков и номер хода.
Следующий код находит n-й ход с использованием хвостовой рекурсии:
public static String N_th_Move(int k_discs, int move){
return HanoiRec(k_discs, move, "A", "B", "C");
}
private static String HanoiRec(int k_discs, int move, String rod_a, String rod_b, String rod_c) {
int max_n_moves = (int) (Math.pow(2, k_discs) - 1);
int bound =(int) Math.pow(2, k_discs - 1);
if(move > max_n_moves){
return "Not valid";
} else if(move == bound ){
return rod_a + " -> " + rod_b;
} else if(move < bound){
return HanoiRec(k_discs-1, move , rod_a, rod_c, rod_b);
} else {
return HanoiRec(k_discs-1, move - bound, rod_c, rod_b, rod_a);
}
}
Как найти n-ю конфигурацию, используя тот же подход?
например:.
N_th_configuation(3, 4) #{rod_a: 0, rod_b: 1, rod_c: 2}
ДОБАВЛЕНО: двоичное дерево для 3 дисков (в соответствии с приведенным выше кодом):
(0 1 2)
/ \
(1 1 1) (0 2 1)
/ \ / \
(2 1 0) (1 0 2) (1 1 1) (0 3 0)
Где первое число - это число дисков на rod_a, второе на rod_b и третье на rod_c.
Нижний левый лист - это конфигурация после первого хода, а нижний правый - это конфигурация после последнего хода.
Я не выясняю связь между всеми конфигурациями.