二叉树中俩点距离就是俩个点的边的条数。
分析
假设给定的节点为node1, node2,可以分为下面两种情况:
1) node1是node2的祖先节点或孩子节点,可以理解为两个节点在一条线上。 例如:Dist(2,4), Dist(6,1)
2) node1 和 node2 没有直接或间接的父子关系。 例如,Dist(4,3), 他们需要一个共同的祖先节点1 连接起来。
这里涉及两个节点的最低公共祖先(LCA)问题,可以参考我的上一篇博客。
通过观察可以总结出下面的公式, lca是两个节点的最低公共祖先节点:
Dist(n1, n2) = Dist(root, n1) + Dist(root, n2) - 2*Dist(root, lca)
<