题目
原题链接
给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)
例如:
给定二叉树 [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回其自底向上的层次遍历为:
[
[15,7],
[9,20],
[3]
]
思路
我们先思考一下,这道题最与众不同的一点是什么?很显然,是它要求我们要倒过来输出。
怎么解决这个问题呢?有一个类似于作弊的方法。
c++vector容器有一个库函数,reverse(),将整个容器逆转过来,至于怎么实现树的遍历与存储,我这里用队列辅助实现。
/**
* 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<vector<int>> ans;
vector<vector<int>> levelOrderBottom(TreeNode* root) {
if(!root) return ans; //空树返回空数组
queue<TreeNode*> q;
q.push(root);
while(!q.empty()) {
vector<int> v; //定义一个新的辅助容器v
for(int i = q.size(); i; -- i) {
TreeNode* temp = q.front(); q.pop();
//将队首取出,放入temp
v.push_back(temp -> val); //将节点的值压入容器内
if(temp -> left) q.push(temp -> left); //压入左儿子
if(temp -> right) q.push(temp -> right);//压入右儿子
}
ans.push_back(v); //将新的一层压入答案内
}
reverse(ans.begin(), ans.end()); //翻转最后答案
return ans;
}
};