【学习笔记】CF1375
这题需要自己构造过程。但是我这方面能力比较差所以还是不会做
显然倒着考虑。如果先手胜利的话那么 a , b , c a,b,c a,b,c一定构成等差数列,并且上一次操作的是 c c c。
再往前倒推一步。接下来就非常有运气成分了:假设 c c c不能操作,并且任意操作 a , b a,b a,b都会构成等差数列,解方程算出来 k = 2 c − a − b k=2c-a-b k=2c−a−b恰好有解,这道题就做完了。
注意到是对相邻的点进行操作,因此猜测存在距离之类的不变量。
假设固定了根节点,那么问题转化为将所有点到根的距离变成 1 1 1,不难发现操作过程中只有一个点距离的奇偶性发生变化,猜测这就是答案的下界。取等分析就不说了。
向来不会工业题
首先考虑一个操作次数 N 2 N^2 N2的解法,我们需要求出所有区间对应的集合。
令 M = ⌊ N 2 ⌋ M=\lfloor\frac{N}{2}\rfloor M=⌊2N⌋,首先求出数组 a i a_i ai权值在 [ 1 , M ] [1,M] [1,M]的子序列对应的所有集合,以及数组 a i a_i ai权值在 [ M + 1 , N ] [M+1,N] [M+1,N]的子序列对应的所有集合,那么原数组的任意区间都可以由至多一次操作拼出。不难验证操作次数不会超过 N 2 N^2 N2。
因为这题很考验代码实现能力,所以还是梳理一下代码实现的细节,不然写起来非常想死
对于原问题,我们考虑对权值进行分块处理 一开始想的是按序列进行分块但是就是很难写所以写不出来,应该是想复杂了 ,对于每一个值域块,我们提取出
[
l
:
r
]
[l:r]
[l:r](询问区间)中在值域块内的数的子序列加入答案,那么对于一个值域块,我们要维护
[
l
,
r
]
[l,r]
[l,r]所对应的答案,转化到子序列中就是
[
l
′
,
r
′
]
[l',r']
[l′,r′]对应的答案。于是只用考虑怎么合并。首先求出
[
l
,
M
]
,
[
M
+
1
,
r
]
[l,M],[M+1,r]
[l,M],[M+1,r]对应的答案(这可以用一个结构体来维护),然后枚举区间,把它在左右两段值域中所对应的两个区间合并起来就是答案。这个地方可以直接二分查找 因为这样比较好写 。取
B
=
Q
B=\sqrt{Q}
B=Q,操作次数我们之前分析过了是
2
N
Q
2N\sqrt{Q}
2NQ次,恰好可以通过。
权衡利弊后,发现还是写一下吧,要是代码能力再退步那就寄了
为了避免繁琐的空间问题,我选择使用 vector \text{vector} vector。
这题也引发了我的思考。遇到这样代码比较复杂的题目,能不能在考场上迅速想到最好实现的那种方法呢?因为我们知道数据结构题实现思路不清晰的话甚至不如暴力。那么我们要冷静下来分析,必要时可以牺牲少量常数换取代码长度,这是对我这样代码能力“不那么强”的oier所需要的。
__EOF__

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