題目需求
給定一個(gè)二叉樹,返回其按層次遍歷的節(jié)點(diǎn)值。 (即逐層地,從左到右訪問所有節(jié)點(diǎn))。
例如:
給定二叉樹: [3,9,20,null,null,15,7],3
/\
9 20
/\
15 7
返回其層次遍歷結(jié)果:[
[3],
[9,20],
[15,7]
]
解題思路
1.廣度優(yōu)先搜索(BFS)
public List<List<Integer>> levelOrder(TreeNode root) {
if (root == null) {
return new ArrayList<>();
}
List<List<Integer>> result = new ArrayList<>();
Queue<TreeNode> queue = new LinkedList<>();
queue.add(root);
while (!queue.isEmpty()) {
int size = queue.size();
List<Integer> list = new ArrayList<>();
for (int i = 0; i < size; i++) {
TreeNode node = queue.poll();
if (node == null) continue;
list.add(node.val);
if (node.left != null)
queue.add(node.left);
if (node.right != null)
queue.add(node.right);
}
result.add(list);
}
return result;
}
2.數(shù)組填充,先將要返回的集合創(chuàng)建好, 然后采用深度優(yōu)先搜索(DFS),根據(jù)二叉樹的層級(jí),進(jìn)行填充
public List<List<Integer>> levelOrder(TreeNode root) {
List<List<Integer>> result = new ArrayList<>();
dfs(result, root, 1);
return result;
}
public void dfs(List<List<Integer>> result, TreeNode node, int level) {
if (node == null) return;
if (result.size() < level) {
result.add(new ArrayList<>());
}
result.get(level - 1).add(node.val);
dfs(result, node.left, level + 1);
dfs(result, node.right, level + 1);
}