计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家

时间:2023-03-09 19:56:20
计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家

传送门

这题可以用线段树来维护

 #include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<map>
#include<set>
#include<queue>
#include<vector>
#define INF 0x7f7f7f7f
#define pii pair<int,int>
#define ll long long
#define MAXN 500005
#define DEBUG 1
using namespace std;
int read(){
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if('-'==ch)f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,T;
int a[MAXN];
int dat[MAXN*];
void build(int k,int L,int R){
if(L+==R){
dat[k]=a[L];
return;
}
build(k<<,L,(L+R)>>);
build(k<<|,(L+R)>>,R);
dat[k]=max(dat[k<<],dat[k<<|]);
}
void change(int a,int k,int L,int R,int x){
if(L+==R){
dat[k]-=x;
return;
}
int mid=(L+R)/;
if(a<mid){
change(a,k<<,L,mid,x);
}
else{
change(a,k<<|,mid,R,x);
}
dat[k]=max(dat[k<<],dat[k<<|]);
}
int ask(int a,int k,int L,int R){
if(L+==R){
return dat[k];
}
int mid=(L+R)/;
if(a<mid){
return ask(a,k<<,L,mid);
}
else{
return ask(a,k<<|,mid,R);
}
}
int Lfind(int a,int b,int k,int L,int R,int x){
if(b<=L||R<=a||dat[k]<x){
return -;
}
if(L+==R){
return L;
}
int t=Lfind(a,b,k<<|,(L+R)>>,R,x);
if(t!=-){
return t;
}
t=Lfind(a,b,k<<,L,(L+R)>>,x);
return t;
}
int Rfind(int a,int b,int k,int L,int R,int x){
if(b<=L||R<=a||dat[k]<x){
return -;
}
if(L+==R){
return L;
}
int t=Rfind(a,b,k<<,L,(L+R)>>,x);
if(t!=-){
return t;
}
t=Rfind(a,b,k<<|,(L+R)>>,R,x);
return t;
}
void init(){
n=read();T=read();
for(int i=;i<=n;i++){
a[i]=read();
}
build(,,n+);
}
void debug(int k,int L,int R){
if(L+==R){
printf("%d ",dat[k]);
return;
}
debug(k<<,L,(L+R)>>);
debug(k<<|,(L+R)>>,R);
}
void solve(){
for(int i=;i<=T;i++){
// debug(1,1,n+1);
// printf("\n");
int x=read(),y=read();
if(dat[]<x){
printf("-1\n");
continue;
}
if(ask(y,,,n+)>=x){
change(y,,,n+,x);
printf("%d\n",y);
continue;
}
int tL=Lfind(,y-+,,,n+,x);
int tR=Rfind(y+,n+,,,n+,x);
if(-==tL||-==tR){
tR=(tL==-?tR:tL);
}
else if(y-tL<=tR-y){
tR=tL;
}
change(tR,,,n+,x);
printf("%d\n",tR);
}
// debug(1,1,n+1);
// printf("\n");
}
int main()
{
// freopen("data.in","r",stdin);
// freopen("my.out","w",stdout);
init();
solve();
return ;
}