day-23 N 叉树的层序遍历

思路:利用bfs,利用队列将当前层的孩子元素加入队列,再将本层元素出队即可

注意点:res.remove()执行后,ArrayList的元素索引会改变,可以先添加下一层所有元素后,再将本层元素一起出队

code:

java 复制代码
/*
// Definition for a Node.
class Node {
    public int val;
    public List<Node> children;

    public Node() {}

    public Node(int _val) {
        val = _val;
    }

    public Node(int _val, List<Node> _children) {
        val = _val;
        children = _children;
    }
};
*/

class Solution {
    public List<List<Integer>> levelOrder(Node root) {
        List<List<Integer>> res=new ArrayList<List<Integer>>();
        if(root==null)return res;
        List<Node> now=new ArrayList<Node>();
        now.add(root);
        while(now.size()>0){
            int num=now.size();
            List<Integer> t=new ArrayList<Integer>();
            for(int i=0;i<num;i++){//遍历同一层元素
                t.add(now.get(i).val);
                int cur=now.get(i).children.size();
                for(int j=0;j<cur;j++){//遍历每个元素的孩子
                    if(now.get(i).children.get(j)!=null){
                        now.add(now.get(i).children.get(j));
                    }
                }
            }
            for(int i=0;i<num;i++){
                now.remove(0);
            }
            res.add(t);
        }
        return res;
    }
}
相关推荐
慕容青峰20 分钟前
蓝桥杯第十五届CA省赛【因数计数】题解
c++·算法·蓝桥杯·sublime text
冠位观测者29 分钟前
常见排序算法总结 (五) - 堆排序与堆操作
数据结构·算法·排序算法
StayInLove1 小时前
线程池中线程异常后到底是怎么处理的
java·jvm·算法
古希腊掌管学习的神2 小时前
[机器学习]AdaBoost(数学原理 + 例子解释 + 代码实战)
人工智能·python·算法·机器学习
山河君2 小时前
音频进阶学习八——傅里叶变换的介绍
学习·算法·音视频·信号处理
重生之我在VS写bug2 小时前
【C语言的奥秘11】指针知识点总结(续)
c语言·开发语言·算法
勤劳的进取家3 小时前
高斯混合模型及最大期望算法(EM)聚类
人工智能·python·算法·机器学习
eternal__day3 小时前
数据结十大排序之(选排,希尔,插排,堆排)
java·数据结构·算法·推荐算法
Hello.Reader3 小时前
深入浅出支持向量机(SVM)
算法·机器学习·支持向量机
数字扫地僧3 小时前
行业前沿技术对语音识别的影响
算法