70. 두 갈래 나무의 차원 훑어보기 II

1711 단어
묘사
두 갈래 나무를 제시하고 그 노드 값이 밑에서 위로 올라가는 차원으로 되돌아간다. (잎 노드가 있는 층에서 뿌리 노드가 있는 층으로 옮겨다닌 다음에 한 층씩 왼쪽에서 오른쪽으로 옮겨간다)
예를 들어 두 갈래 나무 {3,9,20,#,#,15,7},
        3
       / \
      9  20
        /  \
       15   7

다음과 같이 아래에서 위로 이동합니다.
    [
      [15,7],
      [9,20],
      [3]
    ]

코드

/**
 * Definition of TreeNode:
 * public class TreeNode {
 *     public int val;
 *     public TreeNode left, right;
 *     public TreeNode(int val) {
 *         this.val = val;
 *         this.left = this.right = null;
 *     }
 * }
 */
public class Solution {
    /**
     * @param root: The root of binary tree.
     * @return: buttom-up level order a list of lists of integer
     */
    public List> levelOrderBottom(TreeNode root) {
        List> result = new ArrayList<>();
        if (root == null) {
            return result;
        }
        Queue queue = new LinkedList();
        queue.offer(root);
        
        while (!queue.isEmpty()) {
            int size = queue.size();
            List level = new ArrayList<>();
            for (int i = 0; i < size; i++) {
                TreeNode head = queue.poll();
                level.add(head.val);
                if (head.left != null) {
                    queue.offer(head.left);
                }
                if (head.right != null) {
                    queue.offer(head.right);
                }
            }
            result.add(level);
        }
        
        //  , O(n)
        Collections.reverse(result);
        return result;
    }
}

좋은 웹페이지 즐겨찾기