问题定义
如果我们把二叉树看成一个图,父子节点之间的连线看成是双向的,我们姑且定义"距离"为两节点之间边的个数。写一个程序求一棵二叉树中相距最远的两个节点之间的距离。
书上的解法
书中对这个问题的分析是很清楚的,我尝试用自己的方式简短覆述。
计算一个二叉树的最大距离有两个情况:
· 情况A: 路径经过左子树的最深节点,通过根节点,再到右子树的最深节点。
· 情况B: 路径不穿过根节点,而是左子树或右子树的最大距离路径,取其大者。
只需要计算这两个情况的路径距离,并取其大者,就是该二叉树的最大距离。


package facehandjava.tree;
public class MaxDistance {

本文介绍了如何计算二叉树中相距最远的两个节点之间的最大距离。问题定义为在二叉树中找到路径最多的边数。书中提出了两种情况:路径经过左子树最深节点、根节点和右子树最深节点,或者左、右子树的最大距离路径。通过递归实现,分别计算左右子树的深度并比较,以获取最大距离。
最低0.47元/天 解锁文章
1913

被折叠的 条评论
为什么被折叠?



