在Java

时间:2016-12-05 21:35:34

标签: java recursion arraylist combinations

所以我非常接近解决这个算法。这是另一个更长的算法的一部分,我只是在一个ArrayList中找到每个可能的有序整数组合。

我有一个整数{0,1,2}的ArrayList。我想使用成员方法permute()有效地使用递归来解决这个问题。我有原始的ArrayList {0,1,2}并使用ArrayList preArr使用ArrayList helper逐个填充它,直到preArr填充了项目,然后尝试清除preArr和helper以重新填充新的组合。

public class ArrayPermutation {

    ArrayList<Integer> arr = new ArrayList<>();

    public ArrayPermutation(int N) {
        for (int i = 0; i < N; i++) {
            arr.add(i);
            //System.out.println("Arr at index " + i + " ===> " + arr[i]);
        }

    }

    public static void main(String[] args) {
        // Test an integer array and pring all posible combinations
        int N = 3;
        ArrayPermutation a = new ArrayPermutation(N);
        a.solver(N);
    }

    public void solver(int N) {
        ArrayList<Integer> pArr = new ArrayList<>();
        ArrayList<Integer> preArr = new ArrayList<>();

        for (int i = 0; i < N; i++) {
           pArr.add(i);
        }
        permute(preArr, pArr, N);
    }

    public void permute(ArrayList<Integer> preArr, ArrayList<Integer> pArr, int N) {

        int n = pArr.size();
        ArrayList<Integer> helper = new ArrayList<>();

        if(n == 0){
            for (int i = 0; i < preArr.size(); i++) {
                System.out.print(preArr.get(i) + " ");
            }
            System.out.println("");
        } else {
            for (int i = 0; i < n; i++) {
                for(int j = 0; j < n; j++){
                    if(j == i)
                    {
                        preArr.add(pArr.get(j));
                    } 
                    else {
                        helper.add(pArr.get(j));
                    }

                }
                permute(preArr, helper, N);
                preArr.clear();
                helper.clear();
            }

        }

    }

}

从这里开始,我有以下内容。

Expected Output
0 1 2
0 2 1
1 0 2
1 2 0
2 0 1
2 1 0

Actual Output
0 1 2 
2 1 
1 0 2 
2 0 
2 0 1 
1 0 

因为你可以看到我错过了每个第二个列表中的第一个整数。我知道我很接近,我在解决这个特殊问题时遇到了一些麻烦。我已经看过一些使用其他来源的帮助,但是弄清楚我的具体例子有点棘手。我感谢任何帮助!

1 个答案:

答案 0 :(得分:0)

在您完成这组排列之前,您需要清除preArr。您可能想要删除最后一个元素。