/***********************************************題目地址:http://codeforces.com/problemset/problem/46/D題目大意:有一條長度為L的街道,有N個操作,操作有兩種:(1)"1 a",表示有一輛長度為a的車開進來想找停車位;停車位必須滿足與它前面的車距離至少為b,與後面的車距離至少為f;如果能找到這樣的停車位;輸出這輛車的起始位置(且這個位置最小),否則輸出-1;(2)"2 a",表示第a個事件裡進來停車的那輛車開出去了;演算法思想:建立起點為-b,終點為L+f的線段樹;尋找的時候,直接尋找len+b+f的線段樹就可以了;其他地方類似於pku3667;線段樹的更新要用延遲更新;在區間查詢和更新的時候加入一個延遲節點;每次要在下次查詢或者更新到該區間時;再把節點的資訊傳遞到左右孩子的結點上;這樣更新大大減少了時間和空間上的開銷;************************************************/#include<iostream>#include<cstring>#include<cstdlib>#include<cstdio>#include<climits>#include<algorithm>using namespace std;#define L l,m,u<<1#define R m+1,r,u<<1|1const int N =100010;struct darling{ int t,l;} s[N];struct car{ int ls,rs,ms; int flag;} a[N*4];void PushUp(int u,int m)//把當前結點的資訊更新到父結點{ a[u].ls=a[u<<1].ls; a[u].rs=a[u<<1|1].rs; if(a[u].ls==m-(m>>1)) a[u].ls+=a[u<<1|1].ls; if(a[u].rs==(m>>1)) a[u].rs+=a[u<<1].rs; a[u].ms=max(a[u<<1|1].ls+a[u<<1].rs,max(a[u<<1].ms,a[u<<1|1].ms));}void PushDown(int u,int m)//把當前結點的資訊更新給兒子結點{ if (a[u].flag!=-1) { a[u<<1].flag=a[u<<1|1].flag=a[u].flag; a[u<<1].ms=a[u<<1].ls=a[u<<1].rs=a[u].flag?0:m-(m>>1); a[u<<1|1].ms=a[u<<1|1].ls=a[u<<1|1].rs=a[u].flag?0:(m>>1); a[u].flag=-1; }}void build(int l,int r,int u){ a[u].ms=a[u].ls=a[u].rs=r-l+1; a[u].flag=-1; if(l==r) return; int m=(l+r)>>1; build(L); build(R);}void update(int l1,int r1,int c,int l,int r,int u)//區間替換{ if(l1<=l&&r<=r1) { a[u].ms=a[u].ls=a[u].rs=c?0:r-l+1; a[u].flag=c; return; } PushDown(u,r-l+1); int m=(l+r)>>1; if(l1<=m) update(l1,r1,c,L); if(m<r1) update(l1,r1,c,R); PushUp(u,r-l+1);}int query(int w,int l,int r,int u)//查詢滿足條件的最左端點{ if(l==r) return l; PushDown(u,r-l+1); int m=(l+r)>>1; if(a[u<<1].ms>=w)//左兒子的ms值大於等於x,則到左兒子裡去找; return query(w,L); else if(a[u<<1].rs+a[u<<1|1].ls>=w)//如果左兒子的rs加上右兒子的ls大於等於x,則直接返回左兒子的右端點減去左兒子的rs值; return m-a[u<<1].rs+1; return query(w,R);//否則到右兒子裡去找;}int main(){ //freopen("C:\\Users\\Administrator\\Desktop\\kd.txt","r",stdin); int L1,b,f; while(~scanf("%d%d%d",&L1,&b,&f)) { build(-b,L1+f,1); int n; scanf("%d",&n); for(int i=1;i<=n;i++) { int op,x; scanf("%d%d",&op,&x); if(op==1) { s[i].l=x; if(a[1].ms<x+b+f+1) { puts("-1"); s[i].t=-1; } else { int p=query(x+b+f,-b,L1+f,1); printf("%d\n",p+b); s[i].t=p+b; s[i].l=x; update(p+b,p+b+x-1,1,-b,L1+f,1); } } else { s[i].t=-1; update(s[x].t,s[x].t+s[x].l-1,0,-b,L1+f,1); } } } return 0;}