题目描述:
Given a binary tree, find the leftmost value in the last row of the tree.
Example 1:
| 12
 3
 4
 5
 6
 7
 8
 9
 
 | Input:
 2
 / \
 1   3
 
 Output:
 1
 
 
 | 
**Example 2: **
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 
 | Input:
 1
 / \
 2   3
 /   / \
 4   5   6
 /
 7
 
 Output:
 7
 
 
 | 
Note: You may assume the tree (i.e., the given root node) is not NULL.
用DFS/BFS遍历一遍二叉树,要保证左子树比右子树先遍历到,这样没出现一个更深的节点就一定是该深度的最左边的节点。
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 
 | 
 
 
 
 
 
 
 
 class Solution {
 public:
 int findBottomLeftValue(TreeNode* root) {
 return BFS(root);
 }
 
 int BFS(TreeNode *root) {
 queue<TreeNode*> nodeQueue;
 queue<int>       depthQueue;
 nodeQueue.push(root);
 depthQueue.push(0);
 
 int maxDepth = -1;
 int leftBottomVal;
 while (!nodeQueue.empty()) {
 TreeNode *node = nodeQueue.front();
 nodeQueue.pop();
 int depth = depthQueue.front();
 depthQueue.pop();
 if (maxDepth < depth) {
 maxDepth = depth;
 leftBottomVal = node->val;
 }
 if (node->left) {
 nodeQueue.push(node->left);
 depthQueue.push(depth + 1);
 }
 if (node->right) {
 nodeQueue.push(node->right);
 depthQueue.push(depth + 1);
 }
 }
 return leftBottomVal;
 }
 };
 
 |