QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#549317#83. Jumping Grasshopperhhy0613RE 0ms0kbC++142.6kb2024-09-06 14:18:122024-09-06 14:18:12

Judging History

你现在查看的是最新测评结果

  • [2024-09-06 14:18:12]
  • 评测
  • 测评结果:RE
  • 用时:0ms
  • 内存:0kb
  • [2024-09-06 14:18:12]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
const int N=1000005,INF=0x3f3f3f3f;
int a[N];
struct node{
	node *left,*right,*dad;
	int mx,l,r;
}pool[N<<2],*root=nullptr,*ma[N];
int cnt;
node* New(node* fa,int x,int l,int r){
	pool[cnt]=node{nullptr,nullptr,fa,x,l,r};
	return pool+(cnt++);
}
void sol(node* p){p->mx=max(p->left->mx,p->right->mx);}
node* build(int l,int r,node* fa){
	if(l+1==r) return (ma[l]=New(fa,a[l],l,r));
	int mid=l+(r-l)/2;
	node* p=New(fa,0,l,r);
	p->left=build(l,mid,p);
	p->right=build(mid,r,p);
	sol(p);
	return p;
}
void update(node* p,int l,int r,int pos,int x){
	if(l+1==r){
		p->mx=x;
		return;
	}
	int mid=l+(r-l)/2;
	if(pos<mid) update(p->left,l,mid,pos,x);
	else update(p->right,mid,r,pos,x);
	sol(p);
}
int query(node* p,int L,int R,int l,int r){
	if(l>=r) return -INF;
	if(l<=L && R<=r) return p->mx;
	int mid=L+(R-L)/2,ans=-INF;
	if(l<mid) ans=max(ans,query(p->left,L,mid,l,r));
	if(r>mid) ans=max(ans,query(p->right,mid,R,l,r));
	return ans;
}
int searchpre(node* p,int l,int r,int x){
	if(l+1==r) return l;
	int mid=l+(r-l)/2;
	if(p->right->mx>x) return searchpre(p->right,mid,r,x);
	return searchpre(p->left,l,mid,x);
}
int findpre(int pos,int x){
	node* p=ma[pos];
	while(p!=root){
		if(p==p->dad->right){
			node* r=p->dad->left;
			if(r->mx>x) return searchpre(r,r->l,r->r,x);
		}
		p=p->dad;
	}
	return -1;
}
int searchnxt(node* p,int l,int r,int x){
	if(l+1==r) return l;
	int mid=l+(r-l)/2;
	if(p->left->mx>x) return searchnxt(p->left,l,mid,x);
	return searchnxt(p->right,mid,r,x);
}
int findnxt(int pos,int x){
	node* p=ma[pos];
	while(p!=root){
		if(p==p->dad->left){
			node* r=p->dad->right;
			if(r->mx>x) return searchnxt(r,r->l,r->r,x);
		}
		p=p->dad;
	}
	return -1;
}
int main(){
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n,q;
	cin >> n >> q;
	for(int i=0;i<n;++i) cin >> a[i];
	root=build(0,n,nullptr);
	while(q--){
		int op;
		cin >> op;
		if(op==1){
			int pos,val;
			cin >> pos >> val;
			--pos;
			a[pos]=val;
			update(root,0,n,pos,val);
		}else{
			int x;
			char d;
			cin >> x >> d;
			--x;
			if(d=='R'){
				const int lmx=query(root,0,n,0,x),rmx=query(root,0,n,x+1,n);
				if(lmx<a[x]) cout << x+1 << '\n';
				else if(lmx>rmx) cout << findpre(x,max(a[x],rmx))+1 << '\n';
				else cout << findnxt(x,lmx)+1 << '\n';	
			}else{
				const int lmx=query(root,0,n,0,x),rmx=query(root,0,n,x+1,n);
				if(rmx<a[x]) cout << x+1 << '\n';
				else if(lmx<rmx) cout << findnxt(x,max(a[x],lmx))+1 << '\n';
				else cout << findpre(x,rmx)+1 << '\n';	
			}
		}
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 0
Runtime Error

input:

10 4
1 8 5 6 10 20 12 15 2 4
L 2
R 3
U 10 16
L 9

output:


result: