leetcode 102 劍指Offer 32 二叉樹的層次遍歷

Mosiclone發表於2020-09-27

在這裡插入圖片描述
思路不難,直接用佇列迭代就可以。
遍歷過程如下:
在這裡插入圖片描述
程式碼如下:

public class offer32 {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> ans = new LinkedList<>();
        Deque<TreeNode> deque = new LinkedList<>();
        if (root == null) return ans;

        deque.addLast(root);
        while (deque.size() != 0) {
            int size = deque.size();
            List<Integer> an = new LinkedList<>();
            while (size > 0) {
                TreeNode node = deque.pollFirst();
                an.add(node.val);
                if (node.left != null) deque.addLast(node.left);
                if (node.right != null) deque.addLast(node.right);
                size--;
            }
            ans.add(an);
        }
        return ans;
    }
}

相關文章