主席树(可持久化线段树)讲解 [POJ 2104] K-th Number

题目传送门:【POJ 2104】

题目大意:本题包含多组数据。每组数据都会给你一个数组,包含 n 个数;一共有 m 个询问,每次询问输入三个整数 L , R , k,表示求区间 [ L , R ] 以内第 k 小的数。( 1 ≤ n ≤ 100 000 , 1 ≤ m ≤ 5 000 , 数组中每个数的绝对值 ≤ 109 )

知识讲解:
在讲这道题之前,我想先讲讲本人对主席树的一些看法。
主席树,又被称作“可持久化线段树”,是 OI 上一个相当重要的数据结构。它可以解决例如查找历史版本的区间值,区间第 k 大/小值,以及区间内不同数的个数,等等。

既然要实现可持久化,那么在建树过程中,我们就需要将历史信息给记录下来。首先,我们最容易想到的就是:每发生一次修改过程,就建立一棵新树。但是,建立一棵新树的消耗非常大,如果要建立 m 棵新树,复杂度将为

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值