Я пытался реализовать то, что обсуждалось здесь в этой теме Algorithm to apply permutation in constant memory space. Однако я не могу правильно понять решение проблемы, или у моего кода есть ошибка, которую я не могу обнаружить и исправить. Приветственная помощь приветствуется.Не удается получить реализацию на месте перестановки массива на работу
public class ArrayPermute{
public static void main(String[] args){
char[] arr = {'a','b','c','d'};
int[] p = {2,0,1,3};
for(int i=0; i<arr.length; i++){
int tmp = i;
while(p[tmp] >= 0){
char t = arr[p[tmp]];//d
arr[p[tmp]] = arr[tmp];
arr[tmp]=t;
int _tmp = p[tmp];
p[tmp] = -1;
tmp = _tmp;
print(arr);
print(p);
}
}
for(char i: arr){
System.out.print(i + " ");
}
}
public static void print(char[] arr){
for(char c: arr){
System.out.print(c + " ");
}
System.out.println();
}
public static void print(int[] arr){
for(int c: arr){
System.out.print(c + " ");
}
System.out.println();
}
}
Что ваша проблема именно? Вы получаете неправильный вывод? Если да, что вы получаете и чего вы ожидаете? – kraskevich
Да, результат неправильный. – wayfare