LeetCode 102题解 | 二叉树的层序遍历

二叉树的层序遍历

一、题目链接

二叉树的层序遍历

二、题目

三、算法原理

本题要求把结果放在不规则的二维数组里,即每一层二叉树的数值放在一行数组中。

回顾之前的层序遍历是借助队列实现的,是不考虑把结果放在二维数组里的,但是会分不清楚哪个结点是第几层的。怎么实现一层放在一行数组中呢?

两种思路:

  • 思路1:思路简单,但是代码不好实现。只讲思路,定义两个队列,一个存储二叉树结点,一个存储整型数据。
  • 思路2:更简单的思路,最后会有代码实现。只定义存储结点的队列。增加一个变量levelSize,表示每一层二叉树的数据个数。

肯定知道第1层的数据个数,即为1。最先把根结点入栈,变量levelSize置为1。核心逻辑就是用levelSize控制一层一层出队 ,levelSize一旦--,一个结点出栈,同时它的孩子结点入栈。入栈出栈规则与上面的一样:每一个结点出栈,都要把它的孩子结点入栈。

循环:levelSize--,结点9出队,结点9孩子结点入队,再levelSize--,结点20出队,结点20孩子结点入队,此时levelSize为0,表示当前层的结点都出队了,同时也表示下一层的结点也都入队了,再更新变量levelSize,表示下一层的结点个数。

k--走k次,--k走k - 1次。

四、编写代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<vector<int>> vv;
        // 只定义存储结点的队列
        queue<TreeNode*> q;
        int levelSize = 0;
        // 根结点入队,levelSize置为1
        if (root)
        {
            q.push(root);
            levelSize = 1;
        }
        // 一层一层出
        while (!q.empty())
        {
            vector<int> v;
            while (levelSize--)
            {
                TreeNode* front = q.front();
                q.pop();
                v.push_back(front->val);

                // 孩子结点入队
                if (front->left) q.push(front->left);
                if (front->right) q.push(front->right);
            }
            vv.push_back(v);
            levelSize = q.size();
        }
        return vv;
    }
};

队列不为空或者levelSize不为0都可以作为条件:

cpp 复制代码
 while (!q.empty())
 {}

内层循环每走一次就控制一层:

相关推荐
LYFlied1 天前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
踏浪无痕1 天前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试
IMPYLH1 天前
Lua 的 IO (输入/输出)模块
开发语言·笔记·后端·lua
2301_783360131 天前
【学习笔记】关于RNA_seq和Ribo_seq技术的对比和BAM生成
笔记·学习
普通网友1 天前
Objective-C 类的方法重载与重写:区别与正确使用场景
开发语言·ios·objective-c
qq_397731511 天前
Objective-C 学习笔记(第9章)
笔记·学习·objective-c
夏乌_Wx1 天前
练题100天——DAY28:找消失的数字+分发饼干
数据结构·算法
喵了meme1 天前
C语言实战6
c语言·开发语言
AAA阿giao1 天前
从“操纵绳子“到“指挥木偶“:Vue3 Composition API 如何彻底改变前端开发范式
开发语言·前端·javascript·vue.js·前端框架·vue3·compositionapi
小裴(碎碎念版)1 天前
文件读写常用操作
开发语言·爬虫·python