如何计算二叉树的高度 java

如何计算二叉树的高度 java

作者:William Gu发布时间:2026-02-03阅读时长:0 分钟阅读次数:1

用户关注问题

Q
二叉树的高度指的是什么?

在学习如何计算二叉树的高度之前,首先需要明确什么是二叉树的高度?

A

二叉树高度的定义

二叉树的高度是指从根节点到叶子节点的最长路径上的节点数,通常以根节点所在层为起点计算。换句话说,它是树中最大深度的节点数。

Q
Java中实现计算二叉树高度的主要思路有哪些?

在Java中,计算二叉树高度时,有哪些常见的方法或思路可以采用?

A

递归和迭代两种思路

计算二叉树高度常用的方法是递归,通过递归遍历所有子节点,获取左右子树的高度并取最大值加一。另外也可以通过层序遍历(广度优先遍历)实现,如使用队列按层统计节点数。递归实现相对简洁,层序实现直观。

Q
计算二叉树高度的Java示例代码如何写?

有能力展示一段用于计算二叉树高度的Java代码示例吗?

A

示例代码展示

以下是基于递归的方法计算二叉树高度的Java示例代码:

class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode(int val) { this.val = val; }
}

public int getHeight(TreeNode root) {
    if (root == null) {
        return 0;
    }
    int leftHeight = getHeight(root.left);
    int rightHeight = getHeight(root.right);
    return Math.max(leftHeight, rightHeight) + 1;
}

此代码递归计算左右子树的高度,并返回两者的最大值加一作为当前节点的高度。