在不完全二叉树中,节点不一定有两个子节点。通常情况下,某些子节点可能不存在或被删除了,而某些节点会有一个但不是两个子节点。
我们可以使用递归算法来计算不完全二叉树的高度和深度。对于一个节点,我们计算它所有子节点的高度,然后将它们的最大值加1就得到了它的高度。同样地,我们计算它所有子节点的深度,然后将它们的最小值加1就得到了它的深度。其中,空节点的高度为0,深度为正无穷大。下面是Java语言实现该算法的示例代码:
class TreeNode {
TreeNode left;
TreeNode right;
}
int getHeight(TreeNode node) {
if (node == null) {
return 0;
}
return Math.max(getHeight(node.left), getHeight(node.right)) + 1;
}
int getDepth(TreeNode node) {
if (node == null) {
return Integer.MAX_VALUE;
}
return Math.min(getDepth(node.left), getDepth(node.right)) + 1;
}
这里我们定义了一个TreeNode类表示二叉树的节点,包含指向左右子节点的引用。getHeight方法使用递归算法计算节点的高度,getDepth方法使用递归算法计算节点的深度。两个方法都有一个参数,即待计算的节点。如果节点为空,则返回相应的值。此外,我们使用了Math类中的max和min方法求出最大和最小的值。