题目描述

输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。

例如:

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

    3
/ \
9 20
/ \
15 7

返回它的最大深度 3 。

提示:

节点总数 <= 10000

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/er-cha-shu-de-shen-du-lcof

代码实现

/**
* 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:
int maxDepth(TreeNode* root) {
if(!root) return 0;
queue<TreeNode*> node_queue;
TreeNode* p = root;
node_queue.push(p);
int layer_num = 0;
while(!node_queue.empty()) {
queue<TreeNode*> tmp;
while(!node_queue.empty()) {
TreeNode* cur_node = node_queue.front();
if(cur_node->left)
tmp.push(cur_node->left);
if(cur_node->right)
tmp.push(cur_node->right);
node_queue.pop();
}
node_queue = tmp;
layer_num++;
}
return layer_num;
}
};

思路解析

  • 层序遍历二叉树,使用tmp队列存储当前层的所有节点,layer_num++

最新文章

  1. 关于在程序中 文件新生成 在用os.system()程序对新生成的文件处理 举个栗子 如下:
  2. PHP MYSQL单向同步方案
  3. 微信公众号里打开链接下载APP
  4. Python中MySQLdb的事务处理
  5. iOS 微信 音频 视频自动播放
  6. MSGPACK(一)
  7. 搜索提示時jquery的focusout和click事件沖突問題完美解决
  8. 火狐解决 OCSP 回应包含过期信息的问题_firefox吧_百度贴吧
  9. C语言得到当前系统时间
  10. TCP详解
  11. Spring(一):eclipse上安装spring开发插件&amp;下载Spring开发包
  12. tesseract-ocr识别英文和中文图片文字以及扫描图片实例讲解
  13. appium+python搭建自动化测试框架_TestAPP框架(三)
  14. jmeter+maven+jenkins自动化接口测试(下)
  15. 判断DataTale中判断某个字段中包含某个数据
  16. client模式下对应接口加入桥接出错
  17. axur axure rp安装
  18. Jmeter脚本录制方法(一)分别使用Badboy录制和Jmeter自带的代理服务器录制
  19. 【Unity】第7章 输入控制
  20. Java实现批量插入

热门文章

  1. three.js 着色器材质之变量(二)
  2. CSS品控与流程
  3. C#LeetCode刷题-广度优先搜索
  4. C#LeetCode刷题之#674-最长连续递增序列( Longest Continuous Increasing Subsequence)
  5. Homekit_温湿度传感器
  6. 【Spring注解驱动开发】你还不会使用@Resource和@Inject注解?那你就out了!!
  7. python基本数据类型(三)
  8. Nginx的Gzip功能
  9. python利用爬虫获取百度翻译,爱词霸翻译结果,制作翻译小工具
  10. 实现直方图均衡化(java+opencv)