51Nod 1175 区间中第K大的数 (可持久化线段树+离散)
第1行:1个数N,表示序列的长度。(2 <= N <= 50000)
第2 - N + 1行:每行1个数,对应序列中的元素。(0 <= S[i] <= 10^9)
第N + 2行:1个数Q,表示查询的数量。(2 <= Q <= 50000)
第N + 3 - N + Q + 2行:每行3个数,对应查询的起始编号i和结束编号j,以及k。(0 <= i <= j <= N - 1,1 <= k <= j - i + 1)
共Q行,对应每一个查询区间中第K大的数。
5
1
7
6
3
1
3
0 1 1
1 3 2
3 4 2
7
6
1 思路:
可持久化线段树入门题。离散化处理下就好了
其实可持久化线段树跟之前写过的线段树动态开点是差不多的,都是为了维护状态,需要开很多棵线段树来维护。
可持久化线段树维护的是每一次修改后的状态。比如这道题我们就可以利用他的能够查询历史版本的特性来解决 ps:之前有点错误,改正了一遍 实现代码:
#include<bits/stdc++.h>
using namespace std;
const int M = 2e6+;
int idx; //记录目前一共建过多少节点
int sum[M],ls[M],rs[M]; //区间和,左儿子,右儿子
int rt[M]; //每次修改对应的根节点编号
int a[M],ans[M],lst[M],cnt,num[M],n,m; struct node{
int id,l,r,x;
bool operator < (const node &b) const {
return r < b.r;
}
}q[M]; void build(int &k,int l,int r){
//k传的是地址,这样在一层函数中修改k就可以直接修改上一层的lson和rson了
k = ++idx; //为新节点标号
if(l == r) return ; //一定要在创建新节点之后再return
int m = (l + r) >> ;
build(ls[k],l,m);
build(rs[k],m+,r);
} void change(int old,int &k,int l,int r,int p,int x){
k = ++idx; //修改的时候要创建新点
ls[k] = ls[old]; rs[k] = rs[old];
sum[k] = sum[old] + x; //先把原来节点的信息复制过来,顺便修改区间和
if(l == r) return ; //先建点后return
int m = (l + r) >> ;
if(p <= m) change(ls[old],ls[k],l,m,p,x);
else change(rs[old],rs[k],m+,r,p,x);
} int query(int k,int old,int l,int r,int x){
if(l == r) return l;
int m = (l + r) >> ;
int ret = sum[rs[k]] - sum[rs[old]];
if(ret >= x)
return query(rs[k],rs[old],m+,r,x);
else
return query(ls[k],ls[old],l,m,x-ret);
} int find(int x){
return lower_bound(num+,num + cnt + , x) - num;
} int main()
{
ios::sync_with_stdio();
cin.tie(); cout.tie();
cin>>n;
for(int i = ;i <= n;i ++){
cin>>lst[i];a[i] = lst[i];
}
sort(lst+,lst+n+);
for(int i = ;i <= n;i ++){
if(i == ||lst[i] != lst[i-])
num[++cnt] = lst[i];
}
build(rt[],,cnt);
cin>>m;
for(int i = ;i <= m;i ++){
q[i].id = i;
cin>>q[i].l; q[i].l ++;
cin>>q[i].r; q[i].r ++;
cin>>q[i].x;
}
sort(q+,q+m+);
for(int i = ,j = ;i <= n;i ++){
change(rt[i-],rt[i],,cnt,find(a[i]),);
while(q[j].r == i){
ans[q[j].id] = query(rt[i],rt[q[j].l-],,cnt,q[j].x);
j++;
}
}
for(int i = ;i <= m;i ++){
printf("%d\n",num[ans[i]]);
}
return ;
}
51Nod 1175 区间中第K大的数 (可持久化线段树+离散)的更多相关文章
- 51nod p1175 区间中第K大的数
1175 区间中第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 一个长度为N的整数序列,编号0 - N - 1.进行Q次查询,查询编号i至j的所有 ...
- 51nod1175 区间中第K大的数
裸的主席树. #include<cstdio> #include<cstring> #include<cctype> #include<algorithm&g ...
- 51nod 区间中第K大的数
区间中第K大的数 基准时间限制:1 秒 空间限制:131072 KB 一个长度为N的整数序列,编号0 - N - 1.进行Q次查询,查询编号i至j的所有数中,第K大的数是多少. 例如: 1 7 6 ...
- 动态求区间K大值(权值线段树)
我们知道我们可以通过主席树来维护静态区间第K大值.我们又知道主席树满足可加性,所以我们可以用树状数组来维护主席树,树状数组的每一个节点都可以开一颗主席树,然后一起做. 我们注意到树状数组的每一棵树都和 ...
- bzoj4504 k个串 kstring 可持久化线段树 (标记永久化)
[fjwc2015]k个串 kstring [题目描述] 兔子们在玩k个串的游戏.首先,它们拿出了一个长度为n的数字序列,选出其中的一个连续子串,然后统计其子串中所有数字之和(注意这里重复出现的数字只 ...
- 【XSY2720】区间第k小 整体二分 可持久化线段树
题目描述 给你你个序列,每次求区间第\(k\)小的数. 本题中,如果一个数在询问区间中出现了超过\(w\)次,那么就把这个数视为\(n\). 强制在线. \(n\leq 100000,a_i<n ...
- 可持久化线段树(主席树)(图文并茂详解)【poj2104】【区间第k大】
[pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=63740442 向大(hei)佬(e)实力学(di ...
- 51NOD 1105 第K大的数
数组A和数组B,里面都有n个整数. 数组C共有n^2个整数,分别是: A[0] * B[0],A[0] * B[1] ...... A[0] * B[n-1] A[1] * B[0],A[1] * B ...
- AC日记——第K大的数 51nod 1105
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
随机推荐
- debian jessie 网络设置
从stable更换到testing后,更新系统apt-get dist-upgrade,然后是等待, 然后不耐烦了不等了,关机! 第二天早上开机apt-get update,找不到源! 用ifconf ...
- Java IO详解(三)------字节输入输出流
File 类的介绍:http://www.cnblogs.com/ysocean/p/6851878.html Java IO 流的分类介绍:http://www.cnblogs.com/ysocea ...
- 极客互联网电视不是噱头,用户体验成创维G7200核心竞争力
IT产业的迅猛发展带动了智能设备的崛起与繁荣,除已经高度普及的智能手机之外.智能电视.智能可穿戴设备等一大批新兴产品更是让消费者充分感受到了智能科技为生活所带来的变化.以智能电视为例,除了乐视 ...
- Hbase shell 输入无法使用退格键删除解决办法
今天在进入hbase shell终端进行数据查询和添加时,发现输入的命令无法撤回,现将解决办法写下: 1.使用Ctrl + Backspace或Shift + Backspace组合键删除 2.(Se ...
- HO引擎近况20190110
前两天更新完,挺兴奋 趁着兴奋把虚拟机里面的MACOSX从10.12.6升级到了10.14 然后装XCODE,虽然比较熟悉了,但是架不住慢啊 先下载了一个DMG的镜像文件,用不了,转成ISO也不行 然 ...
- 20155318 《网络攻防》 Exp9 Web基础
20155318 <网络攻防> Exp9 Web基础 基础问题 SQL注入攻击原理,如何防御 就是通过把SQL命令插入到"Web表单递交"或"输入域名&quo ...
- 20155330 《网络对抗》 Exp5 MSF基础应用
20155330 <网络对抗> Exp5 MSF基础应用 实践过程记录 主动攻击实践:MS08_067漏洞攻击 攻击机:kali IP地址:192.168.124.132 靶机:windo ...
- HTML基础之DOM操作
DOM(Document Object Model 文档对象模型) 一个web页面的展示,是由html标签组合成的一个页面,dom对象实际就是将html标签转换成了一个文档对象.可以通过dom对象中j ...
- [COCI2017-2018#6] Alkemija
题意 一共有 \(n\) 种物质,已知开始你有 \(m\) 种物质且数量足够多,再给出 \(K\) 个物质的转化规则(一堆物质变成另一堆),问一共能够得到多少种物质. 分析 对 \(n\) 种物质和 ...
- wireshark找不到网卡
在Capture Opinions中的interface若找不到网卡,一般是npf服务没有启动. npf是什么东东 Netgroup Packet Filter 网络数据包过滤器 NPF Device ...