前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode:104_Maximum Depth of Binary Tree | 二叉树的最大深度 | Easy

LeetCode:104_Maximum Depth of Binary Tree | 二叉树的最大深度 | Easy

作者头像
Linux云计算网络
发布2018-01-11 10:49:55
6700
发布2018-01-11 10:49:55
举报
文章被收录于专栏:Linux云计算网络

要求:求二叉树的深度(二叉树的深度为最远叶子节点到根节点的距离,即根节点到最远叶子节点的距离)

代码语言:javascript
复制
Given a binary tree, find its maximum depth.

The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node.

有两种求解的思路,一种采用DFS的思想,一种采用BFS的思想,如下代码所示:

代码语言:javascript
复制
 1 struct TreeNode {
 2     int            val;
 3     TreeNode*    left;
 4     TreeNode*    right;
 5     TreeNode(int x): val(x), left(NULL),right(NULL) {}
 6 };
 7 
 8 //采用DFS的思想
 9 int maxDepth(TreeNode *root)
10 {
11     if (NULL == root)
12         return 0;
13     int l = maxDepth(root->left);
14     int r = maxDepth(root->right);
15 
16     return l > r ? l + 1:r+1;
17     //以上这两种方式有一种更简便的方法
18     //return 1 + max(maxDepth(root->left), maxDepth(root->right));
19 }
20 
21 //采用BFS的方法,引入队列
22 int maxDepth(TreeNode *root)
23 {
24     if (NULL == root)
25         return 0;
26     queue <TreeNode *> que;
27     int nCount = 1;
28     int nDepth = 0;// 记录队列里面每一层上的元素
29 
30     que.push(root);
31     while(!que.empty()) {
32         TreeNode *pTemp = que.front();
33         que.pop();
34         nCount --;
35 
36         if (pTemp->left)
37             que.push(pTemp->left);
38         if (pTemp->right)
39             que.push(pTemp->right);
40         
41         if (nCount == 0) {
42             nDepth ++;
43             nCount = que.size();
44         }
45     }
46     return nDepth;
47 }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014-11-27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档