0
点赞
收藏
分享

微信扫一扫

【手把手带你刷LeetCode】——16.剑指offer之二叉树的最大深度(DFS)


【前言】


今天是力扣打卡第16天!

一转眼就半个月过去了呀,时间过得真是贼快,加油加油,不进则退啦!


【手把手带你刷LeetCode】——16.剑指offer之二叉树的最大深度(DFS)_深度优先

原题


给定一个二叉树,找出其最大深度。

二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。

说明: 叶子节点是指没有子节点的节点。


示例:

给定一个二叉树:

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天!

咱们明儿再见咯,记得加油哦!!


【手把手带你刷LeetCode】——16.剑指offer之二叉树的最大深度(DFS)_算法_02


举报

相关推荐

0 条评论