【学习笔记】NOIP模拟赛 13
B. 游戏(game)
solution
随机化算法万岁。。
显然第二问直接拆成 n n n个 1 1 1即可。
对于第一问,首先考虑拆成 { n } \{n\} {n}, { 1 , n − 1 } , { 2 , n − 2 } \{1,n-1\},\{2,n-2\} {1,n−1},{2,n−2}的情况,这样剩下的方案中答案至少是 4 4 4。
如果 n n n是偶数,考虑把 n n n拆分成两个质数的和。注意到质数可以看成是均匀分布的, 1 ∼ n 1\sim n 1∼n有 O ( n log n ) O(\frac{n}{\log n}) O(lognn)个质数,那么考虑随机化算法,因为解是稠密的,可以看作有 n log 2 n \frac{n}{\log^2 n} log2nn组解。如果保证每次随机的是一个质数的话,正确的概率高达 1 log n \frac{1}{\log n} logn1。
如果 n n n是奇数,那么拆分出来一个 1 1 1,转化到 n n n是偶数的情况。
具体操作是直接从 2 2 2开始枚举质数。
期望复杂度 O ( log n n ) O(\log n\sqrt{n}) O(lognn)。
C. QWQ(qwq)
qwq
给出两棵树,每棵树上每个点的父亲编号小于它的编号,将编号两两配对,使得两棵树中每对点的 LCA 的深度(到根点数)的较小值之和最大。依次加入所有点,点数为偶数时输出答案。 n ≤ 2 × 1 0 5 n \leq 2\times 10^5 n≤2×105
可以发现,一种方案 S S S 的价值就是
∑ d e p 1 ( i ) = d e p 2 ( j ) ∑ ( u , v ) ∈ S [ u , v ∈ T 1 ( i ) ] [ u , v ∈ T 2 ( j ) ] \sum_{dep_1(i) = dep_2(j)}\sum_{(u,v) \in S}[u,v \in T_1(i)][u,v \in T_2(j)] dep1(i)=dep2(j)∑(u,v)∈S∑[u,v∈T1(i)][u,v∈T2(j)]
容易猜到这个和式可以取到理论最大值
∑ d e p 1 ( i ) = d e p 2 ( j ) ⌊ ∣ T 1 ( i ) ∩ T 2 ( j ) ∣ 2 ⌋ \sum_{dep_1(i) = dep_2(j)}\lfloor {|T_1(i)\cap T_2(j)|\over 2 }\rfloor dep1(i)=dep2(j)∑⌊2∣T1(i)∩T2(j)∣⌋
感性理解如何取到上式最大值。考虑从下往上加入每一层的点,如果 ( u , v ) (u,v) (u,v)在 T 1 T1 T1, T 2 T2 T2中同时满足联通,那么就把它们配对。
考虑维护这个东西,加入一个点的时候,遍历两棵树中深度相同的祖先,如果 ∣ T 1 ( i ) ∩ T 2 ( j ) ∣ |T_1(i)\cap T_2(j)| ∣T1(i)∩T2(j)∣是奇数答案加 1 1 1,然后反转其奇偶性。
时间复杂度 O ( n 2 ) O(n^2) O(n2)。可以得到 45 p t s 45pts 45pts。
__EOF__

本文链接:https://www.cnblogs.com/cqbzly/p/17530093.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
2021-10-22 【题解】[AGC002F] Leftmost Ball