题目描述
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度
算法:对于二叉树来说,如果一个根节点没有左右子树结点,则二叉树深度为1,只有左子树,则为左子树深度+1, 反之亦然,对于既有左子树,又有右子树的情况,取左右子树的深度的较大值加一。
代码如下:
public int TreeDepth(TreeNode root) {
if (root == null){
return 0;
}
if (root.left == null && root.right == null){
return 1;
}
int left = TreeDepth(root.left);
int right = TreeDepth(root.right);
return (left > right) ? (left + 1) : (right + 1);
}