题目描述
给定一棵二叉树,返回它的自底向上的层序遍历的结果(即从叶子到根,从左往右,一层一层遍历)。
样例
给定二叉树 [3,9,20,null,null,15,7]
:
3
/ \
9 20
/ \
15 7
自底向上层序遍历的结果是:
[
[15,7],
[9,20],
[3]
]
算法
(BFS) $O(n)$
这道题和 Binary Tree Level Order Traversal 基本一样,只需将结果翻转一下即可。
宽度优先遍历,先从上到下一层一层来做,最后将结果翻转。即:
- 将根节点插入队列中;
- 创建一个新队列,用来按顺序保存下一层的所有子节点;
- 对于当前队列中的所有节点,按顺序依次将儿子加入新队列,并将当前节点的值记录在答案中;
- 重复步骤2-3,直到队列为空为止。
- 将记录的结果翻转。
时间复杂度分析:树中每个节点仅会进队出队一次,所以时间复杂度是 $O(n)$。
C++ 代码
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<int> get_val(vector<TreeNode*> level)
{
vector<int> res;
for (auto &u : level)
res.push_back(u->val);
return res;
}
vector<vector<int>> levelOrderBottom(TreeNode* root) {
vector<vector<int>>res;
if (!root) return res;
vector<TreeNode*>level;
level.push_back(root);
res.push_back(get_val(level));
while (true)
{
vector<TreeNode*> newLevel;
for (auto &u : level)
{
if (u->left) newLevel.push_back(u->left);
if (u->right) newLevel.push_back(u->right);
}
if (newLevel.size())
{
res.push_back(get_val(newLevel));
level = newLevel;
}
else break;
}
reverse(res.begin(), res.end());
return res;
}
};