【LeetCode-简单题】589. N 叉树的前序遍历

文章目录

题目

方法一:单循环栈做法

关键在于子节点的入栈顺序,决定了子节点的出栈顺序,

因为是前序遍历 所以压栈顺序先让右边的入栈 依次往左 这样左边的节点会在栈顶 这样下次优先出栈的是左边的元素 满足前序遍历

java 复制代码
 for(int i = root.children.size()-1 ; i>=0 ;i--)
                stack.push(root.children.get(i));
java 复制代码
class Solution {
    public List<Integer> preorder(Node root) {
        if(root==null) return new ArrayList<>();
        List<Integer> res = new ArrayList<>();
        Deque<Node> stack = new LinkedList<>();
        stack.push(root);
        while(!stack.isEmpty()){
            root  = stack.pop();
            res.add(root.val);

            //因为是前序遍历  所以压栈顺序先让右边的入栈  依次往左  这样左边的节点会在栈顶 这样下次优先出栈的是左边的元素 满足前序遍历
            for(int i = root.children.size()-1 ; i>=0 ;i--)
                stack.push(root.children.get(i));
        }
        return res;
    }
}

方法二:递归

原理和二叉树的前序遍历一样 相当于把左右孩子 改成孩子集合了 孩子变多了而已,核心还是 根左右(先跟 再左孩子 在右孩子)

java 复制代码
class Solution {
    List<Integer> res = new ArrayList<>();
    public List<Integer> preorder(Node root) {
        dfs(root);
        return res;
    }
    public void dfs(Node root){
        if(root == null) return;
        res.add(root.val);//前
        for(Node node : root.children)//中中中中中
        dfs(node);
    }
}
相关推荐
小年糕是糕手1 天前
【C++】C++入门 -- 输入&输出、缺省参数
c语言·开发语言·数据结构·c++·算法·leetcode·排序算法
川Princess1 天前
【面试经验】百度Agent架构研发工程师一面
面试·职场和发展·架构·agent
情怀姑娘1 天前
面试题---------------场景+算法
java·算法·mybatis
chbmvdd1 天前
week5题解
数据结构·c++·算法
用户12039112947261 天前
面试官最爱问的字符串反转:7种JavaScript实现方法详解
算法·面试
vir021 天前
小齐的技能团队(dp)
数据结构·c++·算法·图论
Star在努力1 天前
C语言复习八(2025.11.18)
c语言·算法·排序算法
程序员小远1 天前
如何搭建Appium环境?
自动化测试·软件测试·python·测试工具·职场和发展·appium·测试用例
南山安1 天前
从反转字符串看透面试官的“内心戏”:你的算法思维到底怎么样?
javascript·算法·面试
雪不下1 天前
计算机中的数学:概率(2)
算法