513 Find Bottom Left Tree Value
Input:
2
/ \
1 3
Output:
1Input:
1
/ \
2 3
/ / \
4 5 6
/
7
Output:
7Last updated
Input:
2
/ \
1 3
Output:
1Input:
1
/ \
2 3
/ / \
4 5 6
/
7
Output:
7Last updated
int findBottomLeftValue(TreeNode* root) {
if (!root) return -1;
int deepest_left = root->val;
queue<TreeNode*> q;
q.push(root);
q.push(nullptr);
while (!q.empty()) {
TreeNode *temp = q.front();
q.pop();
if (temp) {
if (temp->left)
q.push(temp->left);
if (temp->right)
q.push(temp->right);
}
else {
if (!q.empty() && q.front()) {
deepest_left = q.front()->val;
q.push(nullptr);
}
}
}
return deepest_left;
}