leetcode 107 Binary Tree Level Order Traversal II(最底层往上依次输出二叉树每一个node的val)
最近要准备面试...虽然leetcode的题目难度比较水..不过白板写代码还是要练下的。。。我所理解的白板写代码。。。大概就是。。。用记事本。。一遍写对代码的能力吧。。。所以我来记录一下。。思路想错的或者没有秒的题目。
(因为题目描述傻逼/数据范围故意坑人/leetcode抽风 / 我自己犯傻逼 等原因 没有一次通过的题目不在记录之列)
题意:给一棵二叉树,从最底层往上依次输出每一个node的val..
思路:一开始以为同一层的一定会在相邻时间内访问。。。后来发现的确是蠢了。。。
因此dfs的时候加了一个level域。。。每次dfs的时候先左后右就好了。。。
注意记得判断root为空的情况。。。
/* ***********************************************
Author :111qqz
Created Time :2017年02月20日 星期一 19时21分51秒
File Name :107.cpp
************************************************ */
/**
* 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:
1 vector<vector<int>>res;
2 vector<int>tmp[1500];
3 int mx_level = 0 ;
4 void dfs( TreeNode* root,int level)
5 {
6// cout<<"level:"<<level<<endl;
7 mx_level = max(mx_level,level);
8 if (root->left!=NULL)
9 {
10 tmp[level].push_back(root->left->val);
11 dfs(root->left,level+1);
12 }
13 if (root->right!=NULL)
14 {
15 tmp[level].push_back(root->right->val);
16 dfs(root->right,level+1);
17 }
18 }
19 vector<vector<int>> levelOrderBottom(TreeNode* root) {
20 if (root==NULL) return res;
21 tmp[0].push_back(root->val);
22 dfs(root,1);
23 for ( int i = mx_level; i>= 0 ; i--)if (!tmp[i].empty()) res.push_back(tmp[i]);
24 return res;
25 }
};