【手把手带你刷LeetCode】——16.剑指offer之二叉树的最大深度(DFS)
【摘要】
【前言】
今天是力扣打卡第16天!
一转眼就半个月过去了呀,时间过得真是贼快,加油加油,不进则退啦!
原题
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例:
给定一个二叉树:
3
...
【前言】
今天是力扣打卡第16天!
一转眼就半个月过去了呀,时间过得真是贼快,加油加油,不进则退啦!
原题
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例:
给定一个二叉树:
3 / \ 9 20 / \ 15 7
返回最大深度为:3
题解:
其实本题用DFS和BFS都可以解决,这里暂时就讲解DFS的做法。
如果我们知道了左子树和右子树的最大深度是left和right,那么该二叉树的深度是max(left, right) + 1; 而左子树和右子树的最大深度也可以用前面的方法算出。
代码执行:
-
/**
-
* Definition for a binary tree node.
-
* struct TreeNode {
-
* int val;
-
* struct TreeNode *left;
-
* struct TreeNode *right;
-
* };
-
*/
-
-
-
int maxDepth(struct TreeNode* root){
-
//找边界
-
if(root == NULL){
-
return 0;
-
}
-
int left = maxDepth(root->left);
-
int right = maxDepth(root->right);
-
-
return left > right ? left + 1 : right + 1;
-
}
结语
今天是力扣打卡第16天!
咱们明儿再见咯,记得加油哦!!
文章来源: bit-runout.blog.csdn.net,作者:安然无虞,版权归原作者所有,如需转载,请联系作者。
原文链接:bit-runout.blog.csdn.net/article/details/121324475
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)