Sword refers to Offer 32-III. Print the binary tree from top to bottom III (layer sequence traversal plus double-ended queue)

Insert picture description here
The odd-numbered layer is required to be in reverse order,
then the odd-numbered layer is added to the head of the queue each time using the nature of the deque

    public List<List<Integer>> levelOrder(TreeNode root) {
    
    
        if (root == null) return new ArrayList<>();
        List<List<Integer>> res = new ArrayList<>();
        Deque<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        int cnt = 0;
        while (!queue.isEmpty()){
    
    
            int size = queue.size();
            LinkedList<Integer> list = new LinkedList<>();
            for (int i = 0; i < size; i++) {
    
    
                TreeNode node = queue.pop();
                if ((cnt & 1) == 0)
                    list.add( node.val);
                else list.addFirst(node.val);
                if (node.left != null) queue.offer(node.left);
                if (node.right != null) queue.offer(node.right);
            }
            res.add(list);
            cnt++;
        }
        return res;
    }

Guess you like

Origin blog.csdn.net/qq_43434328/article/details/115142781