java - ArrayList 随机更新

标签 java arraylist

我有这个简单的程序来计算给定集合的所有子集。

我相信该算法是正确的。 但部分而言:

while (included.size()>0){
    ArrayList<Integer> temp =included.remove(0);
    temp.add(first_element);
    output.add(temp);
}

语句temp.add(first_element)不必要地更新not_included。 请帮我理解为什么。

public class Recursion {

    public static ArrayList<ArrayList<Integer>> getSubsets (ArrayList<Integer> input_set){
        ArrayList<ArrayList<Integer>> output=new ArrayList<ArrayList<Integer>>();

        if (input_set.isEmpty()){
            ArrayList<Integer> this_subset=new ArrayList<Integer>();
            output.add(this_subset);
        }      
        else if (input_set.size()==1){
            ArrayList<Integer> empty_subset=new ArrayList<Integer>();
            output.add(input_set);
            output.add(empty_subset);
        }
        else{
            int first_element=input_set.remove(0);
            ArrayList<ArrayList<Integer>> included = getSubsets(input_set);
            ArrayList<ArrayList<Integer>> not_included = getSubsets(input_set);

            while (included.size()>0){
                ArrayList<Integer> temp =included.remove(0);
                temp.add(first_element);
                output.add(temp);
            }
            while (not_included.size()>0){
                output.add(not_included.remove(0));
            }
        }
        return output;
    }


    public static void main(String[] args) {
        ArrayList<Integer> test= new ArrayList<Integer> ();
        test.add(2);
        test.add(1);
        System.out.print(getSubsets(test));
    }
}

最佳答案

尝试

ArrayList<ArrayList<Integer>> not_included = getSubsets(input_set.clone());

这可能仍然不起作用,因为数组列表的通用类型也是数组列表。搜索“深度复制”即可找到 100% 有效的解决方案。

getSubSet 仅返回指向同一列表的指针,因为参数相同,这就是included 和 not_included 是相同列表的原因。

关于java - ArrayList 随机更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15148071/

相关文章:

Python 数组,试图将文本文件放入数组中

java - Android:从 Java 代码调用 Python 脚本(通过 SL4A)

java - 从数字列表中找到所有不同总和的算法

java - 如何使用 BufferedReader 从命令行输出中获取带有特殊字符的字符串

java - 如何验证我的 SCXML 是否定义了有效的状态机?

java - 从 RecyclerView 中删除项目会导致项目重复

java - 如何使用 while 循环用不同类型的对象填充数组列表

java - 使用 hibernate 和 postgres 增加生成键的起始值

java - 将 HashMap 转换为排序的 ArrayList

java - BlueJ 中的数组列表搜索