博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[HNOI2014]世界树
阅读量:5796 次
发布时间:2019-06-18

本文共 389 字,大约阅读时间需要 1 分钟。

建立虚树

子树外的点的处理很麻烦

考虑怎么找

首先对虚树上的点找到控制它的点的编号

f[i],g[i]往里,往外的最近距离,类似换根,还要记录pr,bc前兄弟后兄弟的前缀f值,还要记录方案

 

发现对于虚树的边,只有两头的点才回“争夺”边的控制权和边下边一堆子树的控制权

对于一条边

如果两端所属编号相同,就是这条边自己了

如果不同,倍增找到中间的位置,然后各居一半

最后dfs自底向上更新答案

我的更新答案的方式是:

边上点的sz减去子树里统计过的总的sz

对于绿色的部分控制范围就这样统计

 

注意:

1.清空虚树上所有的点,包括LCA

2.点之间的边还要考虑两点可能不是出发点(是LCA),延伸距离还要考虑控制点到两个点自己的距离。

3.虚树建立时候可能LCA会算重注意。

转载于:https://www.cnblogs.com/Miracevin/p/10383700.html

你可能感兴趣的文章
6套毕业设计PPT模板拯救你的毕业答辩
查看>>
Windows phone 8 学习笔记
查看>>
我的友情链接
查看>>
sshd_config设置参数笔记
查看>>
LeetCode--112--路径总和
查看>>
感悟贴2016-05-13
查看>>
百度编辑器ueditor 光标位置的坐标
查看>>
DEV-C++ 调试方法简明图文教程(转)
查看>>
库克称未来苹果用户可自己决定是否降频 网友:你是在搞笑吗?
查看>>
Sublime Text 2 技巧
查看>>
参加婚礼
查看>>
刚毕业从事java开发需要掌握的技术
查看>>
vim
查看>>
Java重写equals方法和hashCode方法
查看>>
Spark API编程动手实战-07-join操作深入实战
查看>>
H3C-路由策略
查看>>
v$archive_gap dg dataguard 断档处理 scn恢复
查看>>
Winform打包发布图解
查看>>
PDF文件怎么编辑,超简单的方法
查看>>
EasyUI基础入门之Easyloader(载入器)
查看>>