LCA,即最近公共祖先,在图论中应用比较广泛. LCA的定义如下:给定一个有根树,若节点$z$同时是节点$x$和节点$y$的祖先,则称$z$是$x,y$的公共祖先:在$x,y$的所有公共祖先当中深度最大的称为$x,y$的最近公共祖先.下面给出三个最近公共祖先的例子: 显然,从上面的例子可以得出,$LCA(x,y)$即为$x,y$到根节点的路径的交汇点,也是$x$到$y$的路径上深度最小的节点. 求LCA的方法通常有三种: 向上标记法 树上倍增法 Tarjan算法 当然,求LCA还有其它方法,例如…