【前言】
今天是力扣打卡第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天!
咱们明儿再见咯,记得加油哦!!