【今日爽文】重学wqs二分之我是方案构造者
引入:最小度限制生成树
将连接 的边称为 白边。我们人为地控制“最小”生成树的白边数量,那么其权值一定先减小后增大。其中顶点为真正最小生成树的白边数量。
发现其有凹凸性,于是考虑 wqs 二分,具体如何操作不再详细说明,最终复杂度是 。
除此之外,题目还让我们判断无解。怎么判断呢?我们都知道最后二分出来的点不一定就是 ,而是长这样(不用在意为什么它是凸的):
所以我们找到这里的 和 ,看看是否有 就行啦。
接下来看下一道题:MST Company
它要求我们在上一道题的基础上输出方案。
“直接像上题一样解出答案,然后算一遍不就可以了吗?”
我该怎么保证一定有 条白边而不是 或者 条?
“......”
接下来介绍一种方法:
先贴着 下界()做一次,算出哪些白边是一定要的(必要白边)。然后贴着 上界()做一次,算出最多有多少条白边。
定义 为保证最小生成树的情况下,最多有多少条权值 的白边能在生成树中。 可以在贴上界的时候算出。
然后重新贴 下界()做一次,按边权从小到大加入。假设现在边权为 ,白边数量为 ,并且已经算了边权为 的必要白边。那么只要 ,我就加一条边权为 的非必要白边,知道无边可加或者 。
容易知道,这样构造一定能构造出一种白边数量为 的最小生成树。
注意前面要像上道题一样判无解。
欢迎纠错与指正,但我并不保证我能完全理解以及回答你们的问题。
本文作者:AFewSuns
本文链接:https://www.cnblogs.com/AFewSuns/p/wqs-solution.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步