题目描述:
给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)
解题思路:和 LeetCode-102-二叉树的层序遍历 完全一样,只是最后一句每次都查到最前面.
代码实现:
java
class Solution {
public List<List<Integer>> levelOrderBottom(TreeNode root) {
if (root == null) {
return new ArrayList<>();
}
bfs(root);
return res;
}
List<List<Integer>> res = new LinkedList<>();
private void bfs(TreeNode node) {
if (node == null) {
return;
}
Queue<TreeNode> queue = new LinkedList<TreeNode>();
queue.add(node);
while (!queue.isEmpty()) {
int size = queue.size();
List<Integer> path = new ArrayList<>();
while (size > 0) {
// 弹出队列中的一个元素
TreeNode tmp = queue.poll();
path.add(tmp.val);
if (tmp.left != null) {
queue.add(tmp.left);
}
if (tmp.right != null) {
queue.offer(tmp.right);
}
size--;
}
// 收获结果,和 102题 完全一样,只是最后一句每次都查到最前面
res.add(0, path);
}
}
}