社区讨论

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 条回复,欢迎继续交流。

正在加载回复...