剑指 Offer 32 - I.从上到下打印二叉树

题目描述

原题
从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。
例如: 给定二叉树: [3,9,20,null,null,15,7],
1
3
2
/ \
3
9 20
4
/ \
5
15 7
Copied!
返回:
1
[3,9,20,15,7]
Copied!
提示:
    1.
    节点总数 <= 1000 **

题解

1
/**
2
* Definition for a binary tree node.
3
* public class TreeNode {
4
* int val;
5
* TreeNode left;
6
* TreeNode right;
7
* TreeNode(int x) { val = x; }
8
* }
9
*/
10
class Solution {
11
public int[] levelOrder(TreeNode root) {
12
if(root == null){
13
return new int[0];
14
}
15
List<Integer> list = new ArrayList<>();
16
Queue<TreeNode> queue = new LinkedList<>();
17
queue.offer(root);
18
while(!queue.isEmpty()){
19
int size = queue.size();
20
for(int i = 0;i < size;i++){
21
TreeNode node = queue.poll();
22
list.add(node.val);
23
if(node.left!=null){
24
queue.offer(node.left);
25
}
26
if(node.right!=null){
27
queue.offer(node.right);
28
}
29
}
30
}
31
int[] arr = new int[list.size()];
32
for(int i = 0;i<arr.length;i++){
33
arr[i] = list.get(i);
34
}
35
return arr;
36
}
37
}
Copied!
最近更新 10mo ago
复制链接