记录往集合里添加集合时,用的同一个集合对象,导致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));
相关推荐
初圣魔门首席弟子2 天前
c++ bug 记录(merge函数调用时错误地传入了vector对象而非迭代器。)
java·c++·bug
Qiuner2 天前
历劫波,明真我——Debug Commune
ai·开源·bug·debug·信息差·信息·交流
川石课堂软件测试4 天前
什么是BUG,你对BUG的了解有多少?
android·linux·服务器·python·功能测试·bug·安全性测试
仰望星空的凡人4 天前
【BUG排查】基于RH850F1KMS1的主控出现系统中断错误,调试FEIC的值为0x11
单片机·bug·rh850·renesas
Vanranrr4 天前
Git Commit Message 最佳实践:从一次指针Bug说起
git·bug
初圣魔门首席弟子5 天前
c++ bug 函数定义和声明不一致导致出bug
开发语言·c++·bug
xuyuan19985 天前
修复1个Bug,引爆3个新Bug?回归测试的智慧
功能测试·测试用例·bug
三十_A5 天前
【实录】使用 patch-package 修复第三方 npm 包中的 Bug
前端·npm·bug
BrightMZM5 天前
记录一下Unity的BUG,Trial Version
unity·bug·打包·trial
一只自律的鸡6 天前
【bug日记】python找不到包
bug