0

getVariations メソッドは、それぞれの値が同じ数であるがインデックスが異なる整数配列を取得するために使用されます。これらの組み合わせはすべて「組み合わせ」と呼ばれる配列リストに追加され、配列の配列リストを返します。しかし、メインメソッドでこのように使用される場合

    int[] cp1 = { 1,5,4,3,2};
    ArrayList<int[]> k1 = sol.getVariations(cp1);
    for(int n=0; n<5 ; n++){
        int[] ab = k1.get(3);
        System.out.print(ab[n]);

    }

k1 には目的の結果が含まれていません。それでも、私がここで間違っていることを見つけることができませんでした。このメソッド内で配列リストの「組み合わせ」をチェックすると、目的の結果が得られます。変更および追加された配列が含まれています。しかし、メソッドの戻り配列リストをメソッドの外で使用すると、作業を完了できません。
誰かが助けてくれれば、大いに感謝します。

    public ArrayList<int[]> getVariations(int[] copy){

    int[] cp1 = copy;
    int[] comb = new int[5];
    Boolean b = false;
    Boolean d = false;
    Boolean e = false;
    int m = 0;
    ArrayList<int[]> combination = new ArrayList<int[]>();
    for(int i=0; i<N ; i++){
       aloop: for(int j=0; j<N ; j++){


            for(int k=0; k<N ; k++){


                if(k==i)  {
                    b = true;
                    e = true;
                }
                if(k==i+1){
                    d = true;
                    e = false;
                }
                if(k==j){
                    b = false;
                    e = true;
                    continue;
                }
                if(b && j>=i)
                    comb[k] = cp1[k+1];
                if(!b && j>=i)
                    comb[k] = cp1[k];


                if(e && j<i){
                    comb[k] = cp1[k-1];
                }
                if((j<i || d ) && j<i && !e){
                    comb[k] = cp1[k];
                }

            }
            comb[j] = cp1[i];

            b = false;
            e = false;
            d = false;
            for(int h=0 ; h<N ; h++){
                if(comb[h] == cp1[h]){
                   b = true;
                }
                else{
                    b = false;
                    break;
                }


            }
           if(b){
               b = false;
               continue aloop;
           }

            combination.add(m , comb);
           m++;
            for(int n=0; n<N ; n++){
                int[] ab = combination.get(m-1) ;
                System.out.print(ab[n]);

            }

            System.out.println("");

        }



    }
    System.out.println("");
    return (combination);
}
4

1 に答える 1