1 #include<cstdio>
  2 #include<iostream>
  3 #include<cstdlib>
  4 #include<algorithm>
  5 #define M 200009
  6 #define inf 100000000
  7 #define ll long long
  8 using namespace std;
  9 struct A
 10 {
 11     int l,r,mn[2],mx[2],d[2],v;
 12     ll sum;
 13 }a[M],b,p[M];
 14 int n,m,root,N,tot;
 15 ll lans;
 16 void updata(int k)
 17 {
 18     A l1=a[a[k].l],r1=a[a[k].r];
 19     for(int i=0;i<2;i++)
 20       {
 21         a[k].mn[i]=a[k].mx[i]=a[k].d[i];
 22         if(a[k].l)
 23           a[k].mn[i]=min(a[k].mn[i],l1.mn[i]),a[k].mx[i]=max(a[k].mx[i],l1.mx[i]);
 24         if(a[k].r)
 25           a[k].mn[i]=min(a[k].mn[i],r1.mn[i]),a[k].mx[i]=max(a[k].mx[i],r1.mx[i]);
 26       }
 27     a[k].sum=l1.sum+r1.sum+(ll)a[k].v;
 28     return;
 29 }
 30 bool cmp(A a1,A a2)
 31 {
 32     return a1.d[N]<a2.d[N];
 33 }
 34 int rebuild(int l1,int r1,int now)
 35 {
 36     N=now;
 37     int mid=(l1+r1)>>1;
 38     nth_element(p+l1,p+mid,p+r1+1,cmp);
 39     a[mid]=p[mid];
 40     if(l1<mid)
 41       a[mid].l=rebuild(l1,mid-1,now^1);
 42     else
 43       a[mid].l=0;
 44     if(r1>mid)
 45       a[mid].r=rebuild(mid+1,r1,now^1);
 46     else
 47       a[mid].r=0;
 48     updata(mid);
 49     return mid;
 50 }
 51 void cha(int &k,A b,int now)
 52 {
 53     if(!k)
 54       {
 55         k=++m;
 56         for(int i=0;i<2;i++)
 57           a[k].mn[i]=a[k].mx[i]=a[k].d[i]=b.d[i];
 58         a[k].l=a[k].r=0;
 59       }
 60     if(a[k].d[0]==b.d[0]&&a[k].d[1]==b.d[1])
 61       {
 62         a[k].v+=b.v;
 63         a[k].sum+=b.v;
 64         return;
 65       }
 66     if(a[k].d[now]>b.d[now])
 67       cha(a[k].l,b,now^1);
 68     else
 69       cha(a[k].r,b,now^1);
 70     updata(k);
 71 }
 72 ll zhao(int k,int x1,int y1,int x2,int y2)
 73 {
 74     if(a[k].mn[0]>=x1&&a[k].mn[1]>=y1&&a[k].mx[0]<=x2&&a[k].mx[1]<=y2)
 75       return a[k].sum;
 76     if(a[k].mn[0]>x2||a[k].mn[1]>y2||a[k].mx[0]<x1||a[k].mx[1]<y1)
 77       return 0;
 78     ll tmp=0;
 79     if(a[k].d[0]>=x1&&a[k].d[1]>=y1&&a[k].d[0]<=x2&&a[k].d[1]<=y2)
 80       tmp+=a[k].v;
 81     return tmp+zhao(a[k].l,x1,y1,x2,y2)+zhao(a[k].r,x1,y1,x2,y2);
 82 }
 83  
 84 ll read()
 85 {
 86     ll x=0,f=1;char ch=getchar();
 87     while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
 88     while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
 89     return x*f;
 90 }
 91 int main()
 92 {
 93     n=read();
 94     tot=10000;
 95     for(;;)
 96       {
 97         int a1,a2,a3,a4;
 98         a1=read();
 99         if(a1==3)
100           return 0;
101         a2=read()^lans;
102         a3=read()^lans;
103         a4=read()^lans;
104         if(a1==1)
105           {
106             b.d[0]=a2;
107             b.d[1]=a3;
108             b.v=a4;
109             cha(root,b,0);
110             if(m==tot)
111               {
112                 for(int i=1;i<=m;i++)
113                   p[i]=a[i];
114                 root=rebuild(1,m,0);
115                 tot+=10000;
116               }
117           }
118         else
119           {
120             int a5;
121             a5=read()^lans;
122             printf("%lld\n",lans=zhao(root,a2,a3,a4,a5));
123           }
124       }
125     return 0;
126 }

KDtree

posted on 2016-03-23 05:42  xiyuedong  阅读(245)  评论(1编辑  收藏  举报