π One-stop destination for all your technical interview Preparation π
Given the root of a binary tree, return the bottom-up level order traversal of its nodesβ values. (i.e., from left to right, level by level from leaf to root).
res.size() - 1 - level
position.class Solution {
private:
void levelOrderBottomRec(TreeNode* root, int level, vector<vector<int>>& res)
{
if (root == NULL) {
return;
}
if (level >= res.size()) {
res.insert(res.begin(), vector<int>());
}
res[res.size() - 1 - level].push_back(root->val);
levelOrderBottomRec(root->left, level + 1, res);
levelOrderBottomRec(root->right, level + 1, res);
}
public:
vector<vector<int>> levelOrderBottom(TreeNode* root)
{
vector<vector<int>> res;
if (root == NULL)
return res;
levelOrderBottomRec(root, 0, res);
return res;
}
};
class Solution {
public:
vector<vector<int>> levelOrderBottom(TreeNode* root) {
vector<vector<int>> levelorder;
if(root==NULL){
return levelorder;
}
queue<TreeNode *> q;
q.push(root);
while(!q.empty()){
int sz=q.size();
vector<int> level;
for(int i=0;i<sz;i++){
TreeNode *node= q.front(); q.pop();
if(node->left!=NULL)q.push(node->left);
if(node->right!=NULL)q.push(node->right);
level.push_back(node->val);
}
levelorder.push_back(level);
}
reverse(levelorder.begin(),levelorder.end());
return levelorder;
}
};
class Solution {
public:
vector<vector<int>> levelOrderBottom(TreeNode* root) {
vector<vector<int>> levelorder;
if(root==NULL){
return levelorder;
}
queue<TreeNode *> q;
q.push(root);
while(!q.empty()){
int sz=q.size();
vector<int> level;
for(int i=0;i<sz;i++){
TreeNode *node= q.front(); q.pop();
if(node->left!=NULL)q.push(node->left);
if(node->right!=NULL)q.push(node->right);
level.push_back(node->val);
}
levelorder.insert(levelorder.begin(),level);
}
return levelorder;
}
};