leetcode 107 Binary Tree Level Order Traversal II(最底层往上依次输出二叉树每一个node的val)

最近要准备面试...虽然leetcode的题目难度比较水..不过白板写代码还是要练下的。。。我所理解的白板写代码。。。大概就是。。。用记事本。。一遍写对代码的能力吧。。。所以我来记录一下。。思路想错的或者没有秒的题目。

因为题目描述傻逼/数据范围故意坑人/leetcode抽风 / 我自己犯傻逼 等原因 没有一次通过的题目不在记录之列)

leetcode107

题意:给一棵二叉树,从最底层往上依次输出每一个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:

    vector<vector<int>>res;
    vector<int>tmp[1500];
    int mx_level = 0 ;
    void dfs( TreeNode* root,int level)
    {
//  cout<<"level:"<<level<<endl;
    mx_level = max(mx_level,level);
    if (root->left!=NULL)
    {
        tmp[level].push_back(root->left->val);
        dfs(root->left,level+1);
    }
    if (root->right!=NULL)
    {
        tmp[level].push_back(root->right->val);
        dfs(root->right,level+1);
    }
    }
    vector<vector<int>> levelOrderBottom(TreeNode* root) {
    if (root==NULL) return res; 
        tmp[0].push_back(root->val);
        dfs(root,1);
        for ( int i = mx_level;  i>= 0 ; i--)if (!tmp[i].empty()) res.push_back(tmp[i]);
    return res;
    }

};