【题解】CF1554E - You

题意:给你一棵树,每次删除一个节点 i i i 和所连的边, a [ i ] a[i] a[i] 表示当前点所连的边的条数。令 g c d ( a [ 1 ] , a [ 2 ] , . . . , a [ n ] ) = k gcd(a[1],a[2],...,a[n])=k gcd(a[1],a[2],...,a[n])=k ,求对于 k ∈ [ 0 , n ] k\in [0,n] k[0,n] 的不同序列 a a a 的个数。

solution:

观察到不同的操作顺序可能决定相同的序列 a a a 。例如,所有孤岛的入度为 0 0 0 ,而最终得到的序列只能是 0 {0} 0

方便起见,我们假设 ( u , v ) (u,v) (u,v) 的有向边表示 u u u v v v 先删除,注意 ( u , v ) (u,v) (u,v) 一定是树上的边。这样题意就转化为给每一条边 ( u , v ) (u,v) (u,v) 钦定方向,每个节点的值为 o u t [ i ] out[i] out[i]

因为 ∑ i = 1 n o u t [ i ] = n − 1 \sum_{i=1}^n out[i]=n-1 i=1nout[i]=n1 ,所以如果 k k k 有方案的话,那么 k ∣ n − 1 k|n-1 kn1

于是考虑枚举 k k k 。如果 k = 1 k=1 k=1 那么 f ( k ) = 2 n − 1 f(k)=2^{n-1} f(k)=2n1 。否则 k > 1 k>1 k>1 。那么叶节点是可以确定的。 从下往上传递信息,对于每一个点只有 1 1 1 条边可以支配,可以贪心地选择。

时间复杂度 O ( n d ( n ) ) O(nd(n)) O(nd(n))


__EOF__

本文作者仰望星空的蚂蚁
本文链接https://www.cnblogs.com/cqbzly/p/17530291.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   仰望星空的蚂蚁  阅读(5)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示