题解:

x升序排序

y离散化+树状数组

代码:

#include<bits/stdc++.h>
using namespace std;
const int N=500005;
inline int read()
{
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
int n,m,tot,que,disc[N*3],x[N],y[N],a[N],b[N],c[N],d[N],t[3*N],ans[N][5];
struct data{int x,y,id,f;}q[5*N];
int operator<(data a,data b)
{
    return a.x<b.x||(a.x==b.x&&a.f<b.f);
}
void add(int x,int y)
{
    for (int i=x;i<=tot;i+=i&-i)t[i]+=y;
}
int query(int x)
{
    int sum=0;
    for (int i=x;i;i-=i&-i)sum+=t[i];
    return sum;
}
int find(int x)
{
    int l=1,r=tot;
    while (l<=r)
     {
        int mid=(l+r)>>1;
        if (disc[mid]==x)return mid;
        else if(disc[mid]<x)l=mid+1;
        else r=mid-1;
     }
}
void solve()
{
    sort(q+1,q+que+1);
    for (int i=1;i<=que;i++)
     {
        if (!q[i].f)add(q[i].y,1);
        else 
         {
            int t=query(q[i].y);
            ans[q[i].id][q[i].f]=t;
         }
     }
}
int main()
{
    scanf("%d%d",&n,&m);
    for (int i=1;i<=n;i++)
     {
        scanf("%d%d",&x[i],&y[i]);
        disc[++tot]=y[i];
     }
    for (int i=1;i<=m;i++)
     {
         scanf("%d%d%d%d",&a[i],&b[i],&c[i],&d[i]);
        disc[++tot]=b[i];disc[++tot]=d[i];
     }
    sort(disc,disc+tot+1);
    for (int i=1;i<=n;i++)
     {
        y[i]=find(y[i]);
        q[++que].x=x[i];q[que].y=y[i];
     }
    for (int i=1;i<=m;i++)
     {
        b[i]=find(b[i]);d[i]=find(d[i]);
        q[++que].x=c[i];q[que].y=d[i];q[que].id=i;q[que].f=1;
        q[++que].x=a[i]-1;q[que].y=d[i];q[que].id=i;q[que].f=2;
        q[++que].x=c[i];q[que].y=b[i]-1;q[que].id=i;q[que].f=3;
        q[++que].x=a[i]-1;q[que].y=b[i]-1;q[que].id=i;q[que].f=4;
     }
    solve();
    for (int i=1;i<=m;i++)
     {
        int t=ans[i][1]+ans[i][4]-ans[i][2]-ans[i][3];
        printf("%d\n",t);
     }
    return 0;
}

 

posted on 2018-03-15 21:09  宣毅鸣  阅读(129)  评论(0编辑  收藏  举报