【题解】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]=n−1 ,所以如果 k k k 有方案的话,那么 k ∣ n − 1 k|n-1 k∣n−1 。
于是考虑枚举 k k k 。如果 k = 1 k=1 k=1 那么 f ( k ) = 2 n − 1 f(k)=2^{n-1} f(k)=2n−1 。否则 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 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」