【Hot 100 刷题计划】 LeetCode 102. 二叉树的层序遍历 | C++ 极简 DFS 巧解

LeetCode 102. 二叉树的层序遍历

📌 题目描述

题目级别:中等

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

  • 示例 1:
    输入:root = [3,9,20,null,null,15,7]
    输出:[[3],[9,20],[15,7]]

💡 破题思路:DFS 携带深度参数

虽然题目是"层序遍历",但我们完全可以用深度优先搜索(DFS)来"降维打击"。

核心思路是:在 DFS 向下递归的时候,顺便带上一个表示当前深度的参数 level

当我们走到某一个节点时:

  1. 如果发现结果集 res 的大小正好等于 level,说明当前这一层还没有专属的数组,我们立刻在 res 中压入一个空数组。
  2. 然后,把当前节点的值,精准地放入 res[level] 中。

⚠️ 面试避坑点:

不要将 res 设为类的成员变量(全局变量),否则在处理多个测试用例时,上一次残留的数据会导致结果全部错乱。正确的做法是在主函数中声明,并通过引用传递给 DFS 函数。


💻 C++ 代码实现 (DFS 降维打击版)

cpp 复制代码
class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<vector<int>> res; // 局部变量,保证每次调用都是全新的状态
        dfs(root, 0, res);
        return res;
    }

    // 将 res 以引用形式传入
    void dfs(TreeNode* root, int level, vector<vector<int>>& res)
    {
        if (!root) return;

        // 如果这是该层第一次被访问到,为该层开辟一个新的一维数组
        if (res.size() == level) {
            res.push_back(vector<int>());
        }

        // 将当前节点按层号对号入座
        res[level].push_back(root->val);

        // 递归遍历左右子树,层号 +1
        dfs(root->left, level + 1, res);
        dfs(root->right, level + 1, res);
    }
};
相关推荐
石油人单挑所有2 小时前
基于多设计模式下的同步&异步日志系统测试报告
服务器·c++·vscode·设计模式
人道领域2 小时前
【LeetCode刷题日记】225.用队列实现栈--三招实现栈操作(多种思维)
java·开发语言·算法·leetcode·面试
Tisfy2 小时前
LeetCode 2615.等值距离和:分组(哈希表+前缀和)
算法·leetcode·散列表
小此方3 小时前
Re:从零开始的 C++ 进阶篇(四)工业级 C++ 编程:如何构建异常安全的健壮系统?(含案例分析)
运维·开发语言·c++·安全
电商API_180079052473 小时前
如何实现批量化自动化获取淘宝商品详情数据?爬虫orAPI?
大数据·c++·爬虫·自动化
t***5443 小时前
如何确认 Clang 是否在 Dev-C++ 中成功应用
java·开发语言·c++
楚Y6同学3 小时前
QT之下拉框自动填充功能
开发语言·c++·qt·qt开发技巧·串口下拉填充·网口下拉填充
mjhcsp3 小时前
根号快速计算牛顿迭代法
开发语言·c++·算法·迭代法
菜鸟丁小真3 小时前
LeetCode hot100-79.单词搜索
数据结构·算法·leetcode·深度优先·知识总结