社区讨论
15分求调玄关
P3834【模板】可持久化线段树 2参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mlkgnwft
- 此快照首次捕获于
- 2026/02/13 13:42 6 天前
- 此快照最后确认于
- 2026/02/13 14:11 6 天前
CPP
#include<bits/stdc++.h>
#define maxn 100005
using namespace std;
struct seg{
int v,ls,rs;
}t[maxn<<8];
int rt[maxn<<2],cnt;
void pushup(int o){
t[o].v=t[t[o].ls].v+t[t[o].rs].v;
return;
}
void change(int lsto,int &o,int l,int r,int q,int v){
if(!o)
o=++cnt;
if(l==r){
t[o].v+=v;
return;
}
int mid=l+r>>1;
if(q<=mid){
t[o].rs=t[lsto].rs;
t[o].ls=++cnt;
t[t[o].ls]=t[t[lsto].rs];
change(t[lsto].ls,t[o].ls,l,mid,q,v);
}
else{
t[o].ls=t[lsto].ls;
t[o].rs=++cnt;
t[t[o].rs]=t[t[lsto].rs];
change(t[lsto].rs,t[o].rs,mid+1,r,q,v);
}
pushup(o);
return;
}
int query(int o1,int o2,int l,int r,int q){
if(l==r)
return l;
int mid=l+r>>1,tmp=t[t[o2].ls].v-t[t[o1].ls].v;
if(tmp>=q)
return query(t[o1].ls,t[o2].ls,l,mid,q);
else
return query(t[o1].rs,t[o2].rs,mid+1,r,q-tmp);
}
int lsh[maxn<<2],tot,n,m,node[maxn<<2];
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>node[i];
lsh[i]=node[i];
}
sort(lsh+1,lsh+n+1);
tot=unique(lsh+1,lsh+1+n)-lsh-1;
for(int i=1;i<=n;i++){
node[i]=lower_bound(lsh+1,lsh+tot+1,node[i])-lsh;
change(rt[i-1],rt[i],1,tot,node[i],1);
}
for(int i=1;i<=m;i++){
int l,r,q;
cin>>l>>r>>q;
cout<<lsh[query(rt[l-1],rt[r],1,tot,q)]<<endl;
}
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...