私はこのスレッド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