首页 > 其他分享 >CF906C题解

CF906C题解

时间:2023-10-02 19:22:08浏览次数:43  
标签:连边 连通 题解 非叶 CF906C 节点 这道题

可能更好的阅读体验

大家好,我和 DP 有仇,所以我用猜结论的方法过了这道题。

可能是这道题的一个全新思路,可能人自闭久了什么都能想出来(((

upd:好像这也是官方题解思路,看来大家做题不太喜欢看 CF 官方题解(((

首先考虑一个问题:如果这是一道构造题,怎么构造一组合法的解?
在草稿纸上画了很久之后,我发现:只需要在原图上找到一棵生成树,依此从叶子到根操作所有的点,就能得到一个 \(n\) 个点的团。其中叶子不用操作。那么操作次数是 \(n - leaf_T\) 次。
很难想到更好的策略了。所以我先写了一个枚举哪些点是叶子的 \(\Theta(n^2 2^n)\) 的暴力,发现没有 WA 的点。复制了后面的测试点发现答案都是对的。
很懵逼。外层的枚举叶子应该是无法优化了,内层的 check 怎么优化呢?我们发现我们要 check 两件事:

  • 非叶节点连通
  • 所有叶节点都有向非叶节点的边

可以对于每个点处理它向哪些点连边,用一个二进制数 \(State_i\) 存下来。
第一个要求可以预处理两个一个数组 \(ok_S\),表示 \(S\) 这个集合是否连通。枚举 \(j \in S\) 看 \(j\) 是否向 \(S\) 中其他元素连边就能递推了。
第二个要求可以直接对于每个叶节点的 \(State_i\) 查找是否有非叶节点。

那么复杂度就被降为 \(\Theta(n 2^n)\),就可以通过这道题了。注意特判掉给出的图就是完全图的情况。

怎么证明结论呢?这里用官方题解的话说:

假设被操作的最小点集是 \(T\)。
首先,\(T\) 必然连通,否则在不同的连通块之间就没法加上边。
其次,所有不在 \(T\) 中的点必然和 \(T\) 中的点有连边,否则这些点上无法加上新的边。
现在,我随便找出 \(T\) 的一棵生成树 \(T'\),那么,所有不在 \(T\) 中的点就可以向 \(T'\) 连边,得到一棵以 \(T'\) 为非叶节点的原图的生成树。(\(T'\) 中如果有叶节点就一定不优,矛盾。)结论得证。

当了一把官方题解搬运工

标签:连边,连通,题解,非叶,CF906C,节点,这道题
From: https://www.cnblogs.com/miloHogwarts4ever/p/CF906C.html

相关文章

  • P2230 Tinux系统 题解
    传送门题目大意:一个\(n\)个叶子节点,一个节点最多可以有\(k\)条边连向子节点,每个节点\(i\)有一个权值\(P_{i}\)。记每个节点子树内点的个数(不包括它自己)为\(son_{i}\),那么每个节点对答案的贡献就是\(son_{i}^2\timesP_{i}\)。特别的,根节点贡献为\(0\),求总贡献。两......
  • P1045 麦森数 题解
    传送门前排提醒:本篇题解没有使用压位和快速幂,运用了一种预处理的思想,希望能提供一种新的思路。首先将\(2^{p}-1(d)\)转换为\(1111…111(b)\)。关于第一问:我们先考虑\(2\)进制转\(8\)进制,将每\(3\)位转为\(1\)位,即每\(\log{8}\)位转为\(1\)位。\(2\)进制转......
  • UVA1471 防线 Defense Lines 题解
    传送门首先可以将题意大概可以简化为:取两端不重复的连续子序列,组成一个最长的连续递增子序列。我们先dp预处理出以\(i\)为结尾的连续递增子序列长度\(dpr_{i}\)。同样预处理出以\(i\)为开头的连续递增子序列长度\(dpl_{i}\)。考虑对于每个\(dpr_{i}\),找到满足\(a_{......
  • P5503 灯塔 题解
    决策单调性二分传送门数据加强版:P3515前置知识:二分,决策单调性首先很容易写出答案式子:\[ans_{i}=\max_{j=i}^{n}{(a_{j}-a_{i}+\lceil\sqrt{\left|i-j\right|}\rceil)}\]先将向上取整符号拆掉,只要在输出时处理就行。再将绝对值符号拆掉,分\(j<i\)和\(j>i\)的情况......
  • 题解 Codeforces Round 901 (Div. 1) / CF1874A~E
    题解CodeforcesRound901(Div.1)/CF1874A~E比赛情况:过了AB。赛后发现B是假复杂度。https://codeforc.es/contest/1874A.JellyfishandGameProblemAlice&Bob又在博弈,Alice手上有\(n\)个苹果,第\(i\)个苹果的价值是\(a_i\);Bob手上有\(m\)个苹果,第\(i\)......
  • [题解]AT_abc240_f [ABC240F] Sum Sum Max
    思路题目要求的是\(\max_{a=1}^{n}\{\sum_{i=1}^{a}\sum_{j=1}^{a}{A_j}\}\),所以我们将\(\sum_{i=1}^{a}\sum_{j=1}^{a}{A_j}\)化简一下,得:\[i\timesA_1+(i-1)\timesA_2+\dots+1\timesA_x\]在\(a\)每增加\(1\)时,这个和\(s\)将会变为\(s+......
  • [题解]AT_abc245_f [ABC245F] Endless Walk
    思路首先我们可以发现,在任意一个节点数量大于\(1\)的强连通分量中的点都满足条件。所以,我们可以对这张图跑一边TarJan。但是这样是错的,因为我们还需要考虑节点数量为\(1\)的强连通分量。如果这种连通分量能够到达任意一个节点数量大于\(1\)的强连通分量,那么,这个连通分......
  • CSES.1141 C++题解
    题意传送门有一个长度为\(n\)的歌单,问最长多少首歌互不相同?每首歌用一个\(1-10^9\)的整数表示。样例输入812132742样例输出5算法双指针算法。桶思想。对于歌单中重复出现的数,可以用桶来存储。定义两个指针i,j,i指向大数,j指向小数。当出现某个桶的数大于1时,则......
  • CF1878C Vasilije in Cacak 题解
    题目传送门简化题意有\(t\)组询问,每次询问是否能从\(1\simn\)中选择\(k\)个数使得它们的和为\(x\)。解法考虑临界情况,从\(1\simn\)中选择最小的\(k\)个数时和为\(\sum\limits_{i=1}^ki=\dfrac{(k+1)k}{2}\),从\(1\simn\)中选择最大的\(k\)个数时和为\(......
  • Codeforces 1765H 题解
    题目大意题目大意给定一个\(n\)个点和\(m\)条边的有向图,并给定\(p_1,p_2,\cdots,p_n\)表示第\(i\)个点的拓扑序必须小于等于\(p_i\),求出每个点的最小拓扑序。题解题解题目要求拓扑序尽量小,转换一下就是在反图上拓扑序尽量大。考虑拓扑排序,当一个点不得不入队......