首页 > 其他 > 详细

20191004

时间:2019-10-04 19:21:25      阅读:63      评论:0      收藏:0      [点我收藏+]

A.

解 1

我们发现只需要关心处于结果字符串前 \(k\) 位的字符。
因此考虑从后往前处理。
对于一个询问区间,我们暴力连边,用并查集维护, \(x\) 的父亲等于 \(y\) 相当于位于 \(x\) 的字符是从位于 \(y\) 的字符处复制过来的,然后删掉这个区间,更新其他元素的排名,用线段树维护。复杂度 \(O(k\log k)\)刚好可以通过本题。

解 2

syk:用平衡树维护暴力

复杂度是对的,而且更优: \(O(n\log n+k)\)

B.

\(O(\text{可以通过}15\%\text{的数据})\)
然后你发现,第14个点的答案一定是0。
所以加起来你就有20分了。
然而数据好像锅了。

C.

易得计算 \(f(a,b)\) 的复杂度是 \(\log\) 的。
所以 \(x,y\le 1000\) 的数据是送你的。
然后在打 \(x=1,2,4,y\le 10^{18}\) 的时候,你发现好像是有一些规律的,这使得你能把 \(x\le 1000,y\le 10^{18}\) 的数据都过掉。
剩下的只有\(\text{Q}\color{red}{\text{iyang}}\)

20191004

原文:https://www.cnblogs.com/BlogOfchc1234567890/p/11622887.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!