码迷,mamicode.com
首页 > 其他好文 > 详细

bzoj4059

时间:2018-07-08 16:49:29      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:就是   扫描线   题目   差分   插入   strong   col   删除   nbsp   

题解:

还是一道不错的题目

首先它要求每个区间都满足要求,所以我们很容易想到将它映射到二维平面上

然后我们算出每个数的前驱以及后继li,ri

那么第一维是li-i,第二维是i-ri的区间就是合法的,同理交换

这样就变成了矩形覆盖问题

然后因为是不能遍历所有点的所以二维差分是不行的

2种方法

1.线段树+扫描线,将矩形两条边变为一条插入一条删除 nlogn

2.二维线段树 nlog^2n

另外正解其实也是很好想的

我们注意到如果有一个元素在整个序列中只出现了一次,序列就被分割为两个了

所以我们只要从两边一起向中间寻找就可以了

为什么这个复杂度是对的?

因为它是启发式合并的逆过程,每次分裂的复杂度是较小的那个

*不太想写正解没什么意思。。

代码:

 

bzoj4059

标签:就是   扫描线   题目   差分   插入   strong   col   删除   nbsp   

原文地址:https://www.cnblogs.com/yinwuxiao/p/9280095.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!