面试题32_I_从上到下打印二叉树

2020-02-13  本文已影响0人  shenghaishxt

题目描述

从上往下打印出二叉树的每个节点,同层节点从左至右打印。

题解

利用队列进行简单的层次遍历即可。

public ArrayList<Integer> PrintFromTopToBottom(TreeNode root) {
    ArrayList<Integer> res = new ArrayList<>();
    Queue<TreeNode> queue = new LinkedList<>();

    if (root == null)
        return res;
    queue.offer(root);

    while (!queue.isEmpty()) {
        TreeNode p = queue.poll();
        res.add(p.val);
        if (p.left != null)
            queue.offer(p.left);
        if (p.right != null)
            queue.offer(p.right);
    }
    return res;
}
上一篇下一篇

猜你喜欢

热点阅读