Repository containing solution for #SdeSheetChallenge by striver
Given the root of a binary tree, return the level order traversal of its nodes’ values. (i.e., from left to right, level by level).
class Solution {
public:
vector<vector<int>> levelOrder(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);
}
return levelorder;
}
};
class Solution {
private:
void levelOrderRecursive(TreeNode* root, int level, vector<vector<int>>& res)
{
if (root == NULL) {
return;
}
if (level >= res.size()) {
res.push_back(vector<int>());
}
res[level].push_back(root->val);
levelOrderRecursive(root->left, level + 1, res);
levelOrderRecursive(root->right, level + 1, res);
}
public:
vector<vector<int>> levelOrder(TreeNode* root)
{
vector<vector<int>> res;
if (root == NULL)
return res;
levelOrderRecursive(root, 0, res);
return res;
}
};