一个二维偏序的问题,学过了三维偏序cdq分治之后觉得这个题非常的水。只需按一维排序之后再用树状数组操作即可。——by VANE

#include<bits/stdc++.h>
using namespace std;
const int N=5e5+;
struct qry
{
int x,y,id;
}q[N<<];
struct tree
{
int x,y;
}t[N];
int s[N*],n,m,tmp[N*],num,vis_tim,ans[N*];
bool cmp(qry a,qry b)
{
return a.x<b.x;
}
bool cmpp(tree a,tree b)
{
return a.x<b.x;
}
void add(int x)
{
for(;x<=num;x+=x&-x)
s[x]++;
}
int query(int x)
{
int res=;
for(;x;x-=x&-x)
res+=s[x];
return res;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i)
scanf("%d%d",&t[i].x,&t[i].y);
for(int i=;i<=m;++i)
{
int x,y,xx,yy;scanf("%d%d%d%d",&x,&y,&xx,&yy);
int pos=(i-)*;
q[pos+].x=xx;q[pos+].y=yy;q[pos+].id=pos+;
q[pos+].x=x-;q[pos+].y=y-;q[pos+].id=pos+;
q[pos+].x=xx;q[pos+].y=y-;q[pos+].id=pos+;
q[pos+].x=x-;q[pos+].y=yy;q[pos+].id=pos+;
}
for(int i=;i<=n;++i)
tmp[i]=t[i].y;
for(int i=;i<=m*;++i)
tmp[i+n]=q[i].y;
sort(tmp+,tmp++n+m*);
num=unique(tmp+,tmp++n+*m)-tmp-;
for(int i=;i<=n;++i) t[i].y=lower_bound(tmp+,tmp++num,t[i].y)-tmp;
for(int i=;i<=m*;++i) q[i].y=lower_bound(tmp+,tmp++num,q[i].y)-tmp;
sort(q+,q++*m,cmp);
sort(t+,t++n,cmpp);
int i=,j=;
while(j<=*m)
{
int h=q[j].x;
while(t[i].x<=h&&i<=n) add(t[i].y),++i;
while(j<=*m&&q[j].x==h)
{
ans[q[j].id]+=query(q[j].y);
++j;
}
}
for(int i=;i<=*m;i+=)
printf("%d\n",ans[i]+ans[i+]-ans[i+]-ans[i+]);
}

二维偏序用cdq我是不是有病,我就是要写cdq 15000ms卡过去了

By:大奕哥

 #include<bits/stdc++.h>
using namespace std;
struct node
{
int x,y,w,id,f;
bool operator <(const node &b)const
{
return x==b.x?y<b.y:x<b.x;
}
}q[];
int cnt,maxr,tim;
int t[],v[],ans[],pos[];
inline int lowbit(int x){return x&(-x);}
void add(int x,int w)
{
for(;x<=maxr;x+=lowbit(x))
{
if(v[x]!=tim)
{
v[x]=tim;t[x]=w;
}
else t[x]+=w;
}
}
int query(int x)
{
int an=;
for(;x;x-=lowbit(x))
if(v[x]==tim)
an+=t[x];
return an;
}
void cdq(int l,int r)
{
if(l==r)return;
int mid=(l+r)>>;
cdq(l,mid);cdq(mid+,r);
sort(q+l,q+mid+);sort(q+mid+,q+r+);
tim++;
int i=l,j=mid+;
while(j<=r)
{
while(q[i].f==&&i<=mid)++i;
while(q[j].f==&&j<=r)++j;
if(q[i].x<=q[j].x&&i<=mid)add(q[i].y,q[i].w),++i;
else if(j<=r)ans[q[j].id]+=query(q[j].y),++j;
}
}
int main()
{
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i)
{
int x,y;
scanf("%d%d",&x,&y);x++;y++;
q[++cnt].f=;q[cnt].x=x;q[cnt].y=y;q[cnt].w=;q[cnt].id=cnt;maxr=max(maxr,y);
}
for(int i=;i<=m;++i)
{
int x1,x2,y1,y2;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);x1++;x2++;y1++;y2++;
pos[i]=cnt;maxr=max(maxr,max(y1,y2));
q[++cnt].f=;q[cnt].x=x2;q[cnt].y=y2;q[cnt].id=cnt;
q[++cnt].f=;q[cnt].x=x1-;q[cnt].y=y1-;q[cnt].id=cnt;
q[++cnt].f=;q[cnt].x=x1-;q[cnt].y=y2;q[cnt].id=cnt;
q[++cnt].f=;q[cnt].x=x2;q[cnt].y=y1-;q[cnt].id=cnt;
}
cdq(,cnt);
for(int i=;i<=m;++i)
printf("%d\n",ans[pos[i]+]+ans[pos[i]+]-ans[pos[i]+]-ans[pos[i]+]);
return ;
}

BZOJ1935 园丁的烦恼的更多相关文章

  1. [bzoj1935][Shoi2007]Tree 园丁的烦恼 _树状数组

    Tree 园丁的烦恼 bzoj-1935 Shoi-2007 题目大意:给定平面上的$n$个点,$m$次查询矩形点个数. 注释:$1\le n,m\le 5\cdot 10^5$. 想法:静态二维数点 ...

  2. bzoj1935 [Shoi2007]园丁的烦恼

    bzoj1935 [Shoi2007]园丁的烦恼 有N个点坐标为(xi,yi),M次询问,询问(a,b)-(c,d)的矩形内有多少点. 0≤n≤500000,1≤m≤500000,0≤xi,yi≤10 ...

  3. [bzoj1935][shoi2007]Tree 园丁的烦恼(树状数组+离线)

    1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec  Memory Limit: 357 MBSubmit: 980  Solved: 450[Submit][ ...

  4. BZOJ1935: [Shoi2007]Tree 园丁的烦恼

    1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec  Memory Limit: 357 MBSubmit: 552  Solved: 220[Submit][ ...

  5. bzoj千题计划143:bzoj1935: [Shoi2007]Tree 园丁的烦恼

    http://www.lydsy.com/JudgeOnline/problem.php?id=1935 二维偏序问题 排序x,离散化树状数组维护y #include<cstdio> #i ...

  6. BZOJ 1935: [Shoi2007]Tree 园丁的烦恼 +CDQ分治

    1935: [Shoi2007]Tree 园丁的烦恼 参考与学习:https://www.cnblogs.com/mlystdcall/p/6219421.html 题意 在一个二维平面中有n颗树,有 ...

  7. BZOJ 1935: [Shoi2007]Tree 园丁的烦恼( 差分 + 离散化 + 树状数组 )

    假如矩阵范围小一点就可以直接用二维树状数组维护. 这道题,  差分答案, 然后一维排序, 另一维离散化然后树状数组维护就OK了. ----------------------------------- ...

  8. 1935: [Shoi2007]Tree 园丁的烦恼

    1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec  Memory Limit: 357 MBSubmit: 648  Solved: 273[Submit][ ...

  9. bzoj1382 1935: [Shoi2007]Tree 园丁的烦恼

    1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec  Memory Limit: 357 MBSubmit: 1261  Solved: 578[Submit] ...

随机推荐

  1. 网络流入门--最大流算法Dicnic 算法

    感谢WHD的大力支持 最早知道网络流的内容便是最大流问题,最大流问题很好理解: 解释一定要通俗! 如右图所示,有一个管道系统,节点{1,2,3,4},有向管道{A,B,C,D,E},即有向图一张.  ...

  2. HTTP/2.0 简单总结(转载)

    HTTP/2.0 简单总结(转载于https://linjunzhu.github.io/blog/2016/03/10/http2-zongjie/) 如何使用上 HTTP/2.0 需要浏览器的支持 ...

  3. HDU 2159 FATE (dp)

    题目链接 Problem Description 最近xhd正在玩一款叫做FATE的游戏,为了得到极品装备,xhd在不停的杀怪做任务.久而久之xhd开始对杀怪产生的厌恶感,但又不得不通过杀怪来升完这最 ...

  4. 【nginx+tomcat集群】Nginx1.12.2+Tomcat7集群+负载均衡+Session共享

    今天想着将项目优化一下,就想的实现集群分布,在本机测试:利用nginx+tomcat实现 通过上一篇博客(http://www.cnblogs.com/qlqwjy/p/8535235.html),N ...

  5. 【并行计算】用MPI进行分布式内存编程(二)

    通过上一篇中,知道了基本的MPI编写并行程序,最后的例子中,让使用0号进程做全局的求和的所有工作,而其他的进程却都不工作,这种方式也许是某种特定情况下的方案,但明显不是最好的方案.举个例子,如果我们让 ...

  6. c++动态规划dp算法题

    问题1:找硬币,换钱的方法 输入: penny数组代表所有货币的面值,正数不重复 aim小于等于1000,代表要找的钱 输出:换钱的方法总数 解法1:经典dp,空间复杂度O(n*aim) class ...

  7. MD5做为文件名。机器唯一码有电脑的CPU信息和MAC地址,这两个信息需要在linux或unix系统下才能获取吧。

    可以采用机器(电脑)唯一码 + 上传IP + 当前时间戳 + GUID ( + 随机数),然后MD5做为文件名.机器唯一码有电脑的CPU信息和MAC地址,这两个信息需要在linux或unix系统下才能 ...

  8. java版云笔记(八)之关联映射

    Mybatis关联映射 通过数据库对象之间的关联关系,反映到到实体对象之间的引用. 加载多个表中的关联数据,封装到我们的实体对象中. 当业务对数据库进行关联查询. 关联 <association ...

  9. acm专题---最小生成树

    kruscal(eloge): 题目来源:http://acm.hdu.edu.cn/showproblem.php?pid=1102 Problem Description There are N ...

  10. 千万不要运行的 Linux 命令

    本文中列出的命令绝对不可以运行,即使你觉得很好奇也不行,除非你是在虚拟机上运行(出现问题你可以还原),因为它们会实实在在的破坏你的系统.所以不在root等高级管理权限下执行命令是很好的习惯. 本文的目 ...