记录往集合里添加集合时,用的同一个集合对象,导致bug

java 复制代码
public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode() {}
    TreeNode(int val) { this.val = val; }
    TreeNode(int val, TreeNode left, TreeNode right) {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}
class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        Queue<TreeNode> queue=new LinkedList<>();
        List<List<Integer>> result=new ArrayList<>();
        TreeNode tmp;
        TreeNode flag=new TreeNode(0);
        List<Integer> list=new ArrayList<>();
        if (root==null) return result;
        queue.add(root);
        queue.add(flag);
        while (queue.peek()!=null){
            tmp = queue.poll();
            if (tmp==flag){
                result.add(list);
                list.clear();
                if (queue.peek()!=null){
                    queue.add(flag);
                }
                continue;
            }
            list.add(tmp.val);
            if (tmp.left!=null){
                queue.add(tmp.left);
            }
            if (tmp.right!=null){
                queue.add(tmp.right);
            }
        }
        return result;
    }
}

在解决"二叉树的层序遍历"时,写了以上代码

有一个样例是

java 复制代码
输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

而代码执行结果是

java 复制代码
输入:root = [3,9,20,null,null,15,7]
输出:[[],[],[]]

找到问题:

result里面每个list都是同一个对象,对应同一块内存空间,最终list被清空了,所以导致这样的结果

解决:

java 复制代码
result.add(new ArrayList<>(list));
相关推荐
六天测试工程师1 天前
提的缺陷开发不改,测试该怎么办?
bug
不念霉运2 天前
为什么传统 Bug 追踪系统正在被抛弃?
软件测试·安全·gitee·开源·bug·devsecops
编程乐学(Arfan开发工程师)3 天前
56、原生组件注入-原生注解与Spring方式注入
java·前端·后端·spring·tensorflow·bug·lua
福大大架构师每日一题3 天前
pytorch v2.7.1 发布!全面修复关键BUG,性能与稳定性再升级,2025年深度学习利器必备!
pytorch·深度学习·bug
1nv1s1ble4 天前
记录rust滥用lazy_static导致的一个bug
算法·rust·bug
银色的白6 天前
开发记录:修复一些Bug,并实现两个功能
bug
吃货界的硬件攻城狮7 天前
【BUG】记STM32F030多通道ADC DMA读取乱序问题
stm32·嵌入式硬件·bug
星释7 天前
Yii2项目自动向GitLab上报Bug
前端·gitlab·bug·yii
upp7 天前
【bug】Error: /undefinedfilename in (/tmp/ocrmypdf.io.9xfn1e3b/origin.pdf)
ubuntu·pdf·bug·ghostscript
杨过姑父8 天前
部署开源版禅道,修改apache端口无效解决
bug·apache·软件工程·issue