了解到一个quan新的东西:
用ST表(欧拉序)实现LCA(树上最近公共祖先)
欧拉序
前序遍历得到的序列,叫dfs序
但数字可以重复出现,一进一出,叫欧拉序
会发现根结点总在中间
而根结点是该段序列深度最小的点
因此两个点的LCA,
就是在该序列上两个点第一次出现的区间内深度最小的那个点
即转化为区间RMQ问题,可以用ST表
当然你可以再写一棵线段树(如果有修改操作)文章来源:https://www.toymoban.com/news/detail-433638.html
具体的,【笔记】dfs序,欧拉序,LCA的RMQ解法_dfs序求lca_Little_Fall的博客-CSDN博客文章来源地址https://www.toymoban.com/news/detail-433638.html
到了这里,关于LCA——ST表+欧拉序的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!