描述
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的距离。
样例
样例 1:
输入: tree = {}
输出: 0
样例解释: 空树的深度是0。
样例 2:
输入: tree = {1,2,3,#,#,4,5}
输出: 3
样例解释: 树表示如下,深度是3
1
/ \
2 3
/ \
4 5
它将被序列化为{1,2,3,#,#,4,5}
思路大概就是
递归,在找到最深子叶节点的时候计算深度,返回
之后比较大小
最后返回数值最大的
/**
* Definition of TreeNode:
* class TreeNode {
* public:
* int val;
* TreeNode *left, *right;
* TreeNode(int val) {
* this->val = val;
* this->left = this->right = NULL;
* }
* }
*/
class Solution {
public:
/**
* @param root: The root of binary tree.
* @return: An integer
*/
int dep(TreeNode * root,int deep){
int ma=deep,mb=deep,max=deep;
if(root->left==NULL&&root->right==NULL){
return max;
}
if(root->left!=NULL){
ma= dep(root->left,deep+1);
}
if(root->right!=NULL){
mb= dep(root->right,deep+1);
}
return ma > mb ? ma:mb;
}
int maxDepth(TreeNode * root) {
// write your code here
int max=0;
if(root==NULL){
return 0;
}
max=dep(root,1);
return max;
}
};