题解 | #求二叉树的层序遍历#

求二叉树的层序遍历

https://www.nowcoder.com/practice/04a5560e43e24e9db4595865dc9c63a3

/**
 * struct TreeNode {
 *  int val;
 *  struct TreeNode *left;
 *  struct TreeNode *right;
 *  TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 * };
 */
class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param root TreeNode类
     * @return int整型vector<vector<>>
     */
    vector<vector<int> > levelOrder(TreeNode* root) {
        // write code here
        vector<vector<int>> w;
        if (root==nullptr) return w;
        queue<TreeNode*>tree;
        tree.push(root);
        while (!tree.empty()) {
            vector<int> v;
            int size = tree.size();
            while (size--) {
                root = tree.front();
                tree.pop();
                v.push_back(root->val);
                if (root->left) tree.push(root->left);
                if (root->right) tree.push(root->right);

            }
            w.push_back(v);

        }
        return w;
    }
};

层次遍历,顺序为根节点,左节点,右节点。左节点得左节点、右节点。首先对根节点判断是否为空。 如果不为空,根节点入队。这是第一层,加入vector容器中,使用size来记录队的长度。什么情况下入队?当前队首元素的左孩子存在则入队左孩子,右孩子存在再入队右孩子。对第二层来说,队首第一个节点是第二层最左边的节点。层次遍历要把所有的一层都遍历完才到下一层。那么也就是说,我需要把这一层,每一个节点的左孩子节点和右孩子节点都判断一下处理入队操作。这样出队的时候顺序就是层次遍历的顺序,但是需要注意每一层都要放在一个vector中。

全部评论

相关推荐

点赞 评论 收藏
分享
尊尼获获:闺蜜在哪?
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务