马上就要考一轮了,也该复习一下模板了,把以前的题整理一下,再做一些经典题吧。
数据结构类问题
线段树、树状数组:
1、维护序列上的某些操作,难点主要在merge操作(区间加法)怎么写,当然也可以搬到树上和仙人掌上。
一般支持修改、查询操作。
例:bzoj1018、4034、3306、4094、3529
2、利用问题自身的性质,用一些奇怪的复杂度分析来解决一些问题。
这种问题一般是比较难的,在考场上只能依靠做过的题目来想。
例:
bzoj3672、3533:线段树维护凸包,只能维护在最后插入的操作,不能维护在中间修改的操作(树套树)。
每次询问的时候再暴力对每个节点建凸包,因为线段树每一层总共有n个点,一共log n层,加上暴力建凸包的复杂度,是O(n log^2 n)的。
bzoj4127:因为每个数只会由负变正一次,所以每个节点维护一下负数的最大值。
如果加上这个数会变正,那么暴力修改,否则直接打标记做。
bzoj3165:对x轴建一棵线段树,然后记一个数组记录边界情况。
修改的时候,每个节点可能被分成多个部分,新加入的线段如果完全覆盖,那么就把标记改成这条线段。
否则,判断两条直线的交点,位于左儿子还是右儿子,向左或者向右更新儿子节点。
修改的复杂度是O(nlog^2n)的,比较难想的算法。
bzoj3747、2743:经典做法,如果要求区间内重复的数只算一次,一般都是预处理出pre数组来做。
bzoj3514:同上题,联通块个数=总点数-有贡献的边数。