每日两题 / 104. 二叉树的最大深度 102. 二叉树的层序遍历(LeetCode热题100)

news/2025/1/16 4:47:54/

104. 二叉树的最大深度 - 力扣(LeetCode)
image.png

递归判断,当前节点的最大深度为1 + max(左节点的最大深度,右节点的最大深度)

/*** 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:int dfs(TreeNode *cur){if (cur == nullptr) return 0;return 1 + max(dfs(cur->left), dfs(cur->right));}int maxDepth(TreeNode* root) {return dfs(root);}
};

102. 二叉树的层序遍历 - 力扣(LeetCode)
image.png

使用队列,每次出队前先记录当前队列的长度k,k为层的节点数量
此时只需要将前k个节点出队并将节点的左右子节点入队即可
在出队的同时维护答案

/*** 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>> ans;if (root == nullptr) return ans;queue<TreeNode*> q;q.push(root);while (q.size()){ans.push_back(vector<int>());int k = q.size();for (int i = 0; i < k; ++ i){TreeNode* cur = q.front(); q.pop();ans.back().push_back(cur->val);if (cur->left) q.push(cur->left);if (cur->right) q.push(cur->right);}}return ans;}
};

http://www.ppmy.cn/news/1458924.html

相关文章

商业写字楼如何选择停车场管理系统?停车场管理系统建设有哪些注意事项

在现代商业环境中&#xff0c;写字楼停车场的高效管理对于维护企业形象、提高员工满意度以及增强客户体验至关重要。写字楼停车场管理的特点主要包括高流量、高周转率、多样化的车辆类型、高安全性要求以及对客户体验的重视&#xff0c;那么商业写字楼停车场应该从哪些方面提升…

双指针 Leetcode 151 反转字符串中的单词

双指针 Leetcode 151 反转字符串中的单词 Leetcode 151 学习记录自代码随想录 法一&#xff1a;利用额外空间 class Solution { public:string reverseWords(string s) {istringstream iss(s);vector<string> words_string;string k;while(iss >> k){words_str…

测试项目实战——安享理财1(测试用例)

说明&#xff1a; 1.访问地址&#xff1a; 本项目实战使用的是传智播客的安享理财项目&#xff08;找了半天这个项目能免费用且能够满足测试实战需求&#xff09; 前台&#xff1a;http://121.43.169.97:8081/ 后台&#xff1a;http://121.43.169.97:8082/ &#xff08;点赞收藏…

vue-根据不同的环境配置基地址

本地测试时会把process.env.NODE_ENV设置为development 打包上线时会把process.env.NODE_ENV设置为production vue2环境变量配置 变量命名以VUE_APP_xxx开头, 可以在所有的文件中去获取(建议用它) 1、在根目录创建.env.development文件&#xff08;开发环境&#xff09; E…

JavaSE——异常(2/2)-异常的处理(记录异常并提示 、尝试重新修复)

目录 记录异常并提示 案例演示 流程解析 写法优化 尝试重新修复 开发中对于异常的常见处理方式 一层一层往上抛出异常&#xff0c;并且在最上层捕获异常&#xff0c;分为两种不同的处理方式。 例如&#xff0c;B站网页报错就是采取的第一种方式&#xff1a; 记录异常并…

Python-VBA函数之旅-set函数

目录 一、set函数的常见应用场景&#xff1a; 二、set函数使用注意事项 三、如何用好set函数&#xff1f; 1、set函数&#xff1a; 1-1、Python&#xff1a; 1-2、VBA&#xff1a; 2、推荐阅读&#xff1a; 个人主页&#xff1a; https://blog.csdn.net/ygb_1024?spm1…

OpenBayes 一周速览|Apple 开源大模型 OpenELM 上线;字节发布 COCONut 首个全景图像分割数据集,入选 CVPR2024

公共资源速递 This Weekly Snapshots &#xff01; 5 个数据集&#xff1a; * COCONut 大规模图像分割数据集 * THUCNews 新闻数据集 * DuConv 对话数据集 * 安徽电信知道问答数据集 * Sentiment Analysis 中文情感分析数据集 2 个模型&#xff1a; * OpenELM-3B-Inst…

5G Advanced and Release18简述

5G Advanced 5G-Advanced, formally defined in 3GPP Release 18, represents an upgrade to existing 5G networks. 先睹robot总结的5G Advanced的advancements: Enhanced Mobility and Reliability: 5G-Advanced will support advanced applications with improved mobility…