SDOI知识点大复习

马上就要考一轮了,也该复习一下模板了,把以前的题整理一下,再做一些经典题吧。


数据结构类问题

线段树、树状数组

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:同上题,联通块个数=总点数-有贡献的边数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值