[poj2104]可持久化线段树入门题(主席树)
解题关键:离线求区间第k小,主席树的经典裸题;
对主席树的理解:主席树维护的是一段序列中某个数字出现的次数,所以需要预先离散化,最好使用vector的erase和unique函数,很方便;如果求整段序列的第k小,我们会想到离散化二分和线段树的做法, 而主席树只是保存了序列的前缀和,排序之后,对序列的前缀分别做线段树,具有差分的性质,因此可以求任意区间的第k小,如果主席树维护索引,只需要求出某个数字在主席树中的位置,即为sort之后v中的索引;若要求第k大,建树时反向排序即可
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<vector>
- #include<cstdlib>
- #include<iostream>
- #include<cmath>
- using namespace std;
- const int maxn=2e5+;
- int root[maxn];
- struct node{
- int l,r,sum;
- }p[maxn*];
- int cnt=;
- //建树从1开始建
- //rt是当前节点在p数组中的坐标
- int build(int l,int r){
- int rt=++cnt;
- p[rt].sum=;
- p[rt].l=p[rt].r=;
- if(l==r) return rt;
- int mid=(l+r)>>;
- p[rt].l=build(l,mid);
- p[rt].r=build(mid+,r);
- return rt;
- }//开始先建一棵空树,其实可以动态开点,就是各节点均为0
- int update(int l,int r,int c,int k){//update更新的是索引
- int nc=++cnt;
- p[nc]=p[c];
- p[nc].sum++;
- int mid=(l+r)>>;
- if(l==r) return nc;
- if(mid>=k) p[nc].l=update(l,mid,p[c].l,k);
- else p[nc].r=update(mid+,r,p[c].r,k);
- return nc;
- }
- int query(int l,int r,int x,int y,int k){
- if(l==r) return l;
- int mid=(l+r)>>;
- int sum=p[p[y].l].sum-p[p[x].l].sum;
- if(sum>=k) return query(l,mid,p[x].l,p[y].l,k);
- else return query(mid+,r,p[x].r,p[y].r,k-sum);
- }
- vector<int>v;
- int a[maxn];
- int getid(int x){
- return int(lower_bound(v.begin(),v.end(),x)-v.begin())+;
- }
- int main(){
- ios::sync_with_stdio();
- cin.tie();
- cout.tie();
- int n,m;
- cin>>n>>m;
- for(int i=;i<=n;i++){
- cin>>a[i];
- v.push_back(a[i]);
- }
- sort(v.begin(),v.end());
- v.erase(unique(v.begin(), v.end()),v.end());
- //建树过程很重要
- //root[0]=build(1,v.size());//一定注意更新root数组
- //或者上面这句就不需要
- for(int i=;i<=n;i++){
- root[i]=update(,n,root[i-],getid(a[i]));//update是更新某个数出现次数的
- }
- int c,d,q;
- for(int i=;i<m;i++){
- cin>>c>>d>>q;
- int ans=query(,n,root[c-],root[d],q);
- cout<<v[ans-]<<endl;
- }
- return ;
- }
[poj2104]可持久化线段树入门题(主席树)的更多相关文章
- poj 2104 K-th Number (划分树入门 或者 主席树入门)
题意:给n个数,m次询问,每次询问L到R中第k小的数是哪个 算法1:划分树 #include<cstdio> #include<cstring> #include<alg ...
- 【刷题】洛谷 P3834 【模板】可持久化线段树 1(主席树)
题目背景 这是个非常经典的主席树入门题--静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 输入输 ...
- POJ 2104 K-th Number && 洛谷 P3834 【模板】可持久化线段树 1(主席树)
我惊奇的发现这两道题一模一样 题目背景 这是个非常经典的主席树入门题——静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个整数构成的序列,将对于指定的闭区间查询 ...
- 洛谷P3834 [模板]可持久化线段树1(主席树) [主席树]
题目传送门 可持久化线段树1(主席树) 题目背景 这是个非常经典的主席树入门题——静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定 ...
- 洛谷P3834【模板】可持久化线段树 1(主席树)
题目背景 这是个非常经典的主席树入门题--静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 输入输 ...
- LuoguP3834 【模板】可持久化线段树 1(主席树)|| 离散化
题目:[模板]可持久化线段树 1(主席树) 不知道说啥. #include<cstdio> #include<cstring> #include<iostream> ...
- 【洛谷P3834】(模板)可持久化线段树 1(主席树)
[模板]可持久化线段树 1(主席树) https://www.luogu.org/problemnew/show/P3834 主席树支持历史查询,空间复杂度为O(nlogn),需要动态开点 本题用一个 ...
- 【POJ2104】【HDU2665】K-th Number 主席树
[POJ2104][HDU2665]K-th Number Description You are working for Macrohard company in data structures d ...
- dfs序+主席树 或者 树链剖分+主席树(没写) 或者 线段树套线段树 或者 线段树套splay 或者 线段树套树状数组 bzoj 4448
4448: [Scoi2015]情报传递 Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 588 Solved: 308[Submit][Status ...
- BZOJ_1901_Zju2112 Dynamic Rankings_树状数组+主席树
BZOJ_1901_Zju2112 Dynamic Rankings_树状数组+主席树 题意: 给定一个含有n个数的序列a[1],a[2],a[3]……a[n],程序必须回答这样的询问:对于给定的i, ...
随机推荐
- 查询某个字段为null并且某个字段不为null的数据
查询代码为null且ggid不为null的公司名 select name_of_invested_company from dwtz WHERE code is NULL and ggid is no ...
- Swift 闭包的简单学习
OC中已经学习了闭包 在swift里面 该怎么处理 不多说 上代码 //(num:Int) ->Bool是闭包的参数类型 func hasCloserMatch(arr :[Int], valu ...
- StartUML如何画“不折弯”的直线
将下图中line style改成 OBlique.快捷键Ctrl +B
- 纯CSS3实现关闭按钮
在线演示 本地下载
- Android蓝牙开发浅析【转】
本文转载自:http://blog.csdn.net/geekdonie/article/details/7487761 由于近期正在开发一个通过蓝牙进行数据传递的模块,在参考了有关资料,并详细阅读了 ...
- Spring Cloud之服务治理(注册发现)
服务治理SpringCloud Eureka 什么是服务治理 在传统rpc远程调用中,服务与服务依赖关系,管理比较复杂,所以需要使用服务治理,管理服务与服务之间依赖关系,可以实现服务调用.负载均衡.容 ...
- LINQ 学习路程 -- 查询操作 Conversion Operators
Method Description AsEnumerable Returns the input sequence as IEnumerable<t> AsQueryable Conve ...
- SpringCloud-断路器(Hystrix)
在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用Rest Template + Ribbon和Feign来调用.为了保证其高可用,单 ...
- ML2 Extension Manager
The extension manager for ML2 was introduced in Juno (more details can be found in the approvedspec) ...
- Storm- 使用Storm实现词频汇总
需求:读取指定目录的数据,并实现单词计数的功能 实现方案: Spout来读取指定目录的数据,作为后续Bolt处理的input 使用一个Bolt把input 的数据,切割分开,我们按照逗号进分割 使用一 ...