记录往集合里添加集合时,用的同一个集合对象,导致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 天前
重学安卓14/15自由窗口freeform企业实战bug-学员作业
android·framework·bug·systrace·安卓framework开发·安卓窗口系统·自由窗口
Bear on Toilet2 天前
Bug日记——实现“日期类”
开发语言·c++·bug
Direction_Wind2 天前
flinksql bug : Max aggregate function does not support type: CHAR
bug
mg6682 天前
Python Bug 修复案例分析:多线程数据竞争引发的bug 两种修复方法
bug
黎猫大侠3 天前
一次Android Fragment内存泄露的bug解决记录|Fragment not attach to an Activity
android·bug
七七小报3 天前
uniapp-商城-48-后台 分类数据添加修改弹窗bug
uni-app·bug
windwind20003 天前
发行基础:本地化BUG导致审核失败
游戏·青少年编程·编辑器·bug·创业创新·玩游戏
Htht1114 天前
【Qt】之【Bug】点击按钮(ui->pushButton)触发非本类设置的槽函数
qt·ui·bug
gxn_mmf4 天前
典籍知识问答模块AI问答功能feedbackBug修改+添加对话名称修改功能
前端·后端·bug
marvindev4 天前
提bug测试专用
开发语言·javascript·bug