刷题-Leetcode-107. 二叉树的层序遍历 II

107. 二叉树的层序遍历 II

题目链接

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-tree-level-order-traversal-ii/

题目描述

给定一个二叉树,返回其节点值自底向上的层序遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)

例如:
给定二叉树 [3,9,20,null,null,15,7],

3

/
9 20
/
15 7
返回其自底向上的层序遍历为:

[
[15,7],
[9,20],
[3]
]

题目分析

和102题很像

/**
 * 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>> levelOrderBottom(TreeNode* root) {
    
    
        vector<vector<int>> result;
        if(root == nullptr){
    
    
            return result;
        }
        queue<TreeNode*> queue;
        queue.push(root);
        int n;//存放每层节点数
        while(!queue.empty()){
    
      
            vector<int> tmp;
            n = queue.size();
            while(n--){
    
    
                root = queue.front();//注意放while里面
                if(root->left) queue.push(root->left);
                if(root->right) queue.push(root->right);
                tmp.push_back(root->val);
                queue.pop();
            }
            result.push_back(tmp);
        }
        reverse(result.begin(),result.end());
        return result;
    }
};

猜你喜欢

转载自blog.csdn.net/qq_42771487/article/details/113689600