luoguP2163 [SHOI2007]园丁的烦恼
安利系列博文
https://www.cnblogs.com/tyner/p/11565348.html
https://www.cnblogs.com/tyner/p/11605073.html
题意
https://www.luogu.org/problem/P2163
如摘要所示,二位静态数点
分析
离线下来
先,按照y为第一关键字,x为第二关键字排序,把n个数点,和询问的4*m个点都加进去,然后优先数点
这样就可以用关于 x 的树状数组进行求和和加点操作,进而用查询矩形的四个端点的sum加加减减就好了
可是这代码不知道为什么RE了一个点,,,以后再调吧
小伙伴们记得提醒博主这个傻子哦...
或者大佬能帮我调调....
(RE对于博主来说,只是常规操作..)
#include<cstdio>
#include<algorithm>
using namespace std;
const int MAX = 500000+99;
const int INF = 2147000047;
int n,m;
int t[MAX];
struct node{
int xx, x, y;//x为离散化之后的x坐标
int is;//is = 1表示数点, 0表示查询点
//这样我们就可以在排序的时候分清数点与查询点 ,并且优先数点了
int id;
//用以按要求输出答案
node(int xx=0, int y=0, int is=0, int id=0) : xx(xx), y(y), is(is), id(id) {}
}d[MAX*5];
bool cmp1(node a, node bb) {
if(a.y == bb.y) {
if(a.x == bb.x) return a.is > bb.is;
return a.x < bb.x;
}
return a.y < bb.y;
}
bool cmp2(node a, node bb) {
return a.xx < bb.xx;
}
int cnt, max_x, ans[MAX];//ans[id] = 第id个查询点的前缀和
void add_node(int xx, int y, int is, int id) {
++cnt;
d[cnt] = node(xx, y, is, id);
}
bool cmp3(node a, node bb) {
return a.id < bb.id;
}
void add(int x, int k) { while(x <= max_x) t[x] += k, x += x&(-x);}
int query(int x) {
int res = 0;
while(x) res += t[x], x -= x&(-x);
return res;
}
void init() {
scanf("%d%d",&n,&m);
int x1, y1, x2, y2;
for(int i = 1; i <= n; i++) {
scanf("%d%d",&x1, &y1);
add_node(x1, y1, 1, INF);
}
for(int i = 1; i <= (m<<2); i += 4) {
scanf("%d%d%d%d", &x1, &y1, &x2, &y2);
add_node(x2, y2, 0, i);
add_node(x1-1, y2, 0, i+1);
add_node(x2, y1-1, 0, i+2);
add_node(x1-1, y1-1, 0, i+3);
}
sort(d+1, d+1+cnt, cmp2);
int tot = 1;
d[1].x = 1;//记得初始化成1
for(int i = 2; i <= cnt; i++) {
if(d[i].xx != d[i-1].xx) ++tot;
d[i].x = tot;
}
max_x = d[cnt].x;
// for(int i = 1; i <= cnt; i++) {
// if(d[i].is == 1) printf("数点:");
// else printf("查询点%d为", d[i].id);
// printf("%d %d\n", d[i].x, d[i].y);
// }
}
void print_ans() {
sort(d+1, d+1+cnt, cmp3);
for(int i = 1; i <= (m<<2); i += 4) printf("%d\n", ans[i]-ans[i+1]-ans[i+2]+ans[i+3]);
}
void solve() {
sort(d+1, d+cnt+1, cmp1);
for(int i = 1; i <= cnt; i++) {
if(d[i].is == 1) add(d[i].x, 1);//会重复加点吗
else ans[d[i].id] = query(d[i].x);
}
print_ans();
}
int main() {
init();
solve();
return 0;
}
/*
3 1
0 0
0 1
1 0
0 0 1 1
*/
luoguP2163 [SHOI2007]园丁的烦恼的更多相关文章
- [LuoguP2163][SHOI2007]园丁的烦恼_CDQ分治
园丁的烦恼 题目链接:https://www.luogu.org/problem/P2163 数据范围:略. 题解: 树套树过不去,那就$CDQ$分治好了. 有点小细节,但都是$CDQ$分治必要的. ...
- P2163 [SHOI2007]园丁的烦恼
题目 P2163 [SHOI2007]园丁的烦恼 做法 关于拆点,要真想拆直接全部用树状数组水过不就好了 做这题我们练一下\(cdq\)分治 左下角\((x1,y1)\)右上角\((x2,y2)\), ...
- bzoj1935 [Shoi2007]园丁的烦恼
bzoj1935 [Shoi2007]园丁的烦恼 有N个点坐标为(xi,yi),M次询问,询问(a,b)-(c,d)的矩形内有多少点. 0≤n≤500000,1≤m≤500000,0≤xi,yi≤10 ...
- 洛谷 P2163 [SHOI2007]园丁的烦恼 (离线sort,树状数组,解决三维偏序问题)
P2163 [SHOI2007]园丁的烦恼 题目描述 很久很久以前,在遥远的大陆上有一个美丽的国家.统治着这个美丽国家的国王是一个园艺爱好者,在他的皇家花园里种植着各种奇花异草. 有一天国王漫步在花园 ...
- P2163 【[SHOI2007]园丁的烦恼】
其实是不用把一个询问拆成四个的 把询问转化为数学语言: 对于每个查询,询问满足$a<=x<=b$且$c<=y<=d$的点$x,y$的个数 ~~自然~~想到偏序问题,看到有两个式 ...
- P2163 [SHOI2007]园丁的烦恼(cdq分治)
思路 其实是cdq的板子 题目要求询问对于每个给出的xi,yi,xj,yj形如xi<=x<=xj.yi<=y<=yj的x,y对数有多少组 改成四个询问,拆成四个前缀和的形式后就 ...
- BZOJ1935或洛谷2163 [SHOI2007]园丁的烦恼
BZOJ原题链接 洛谷原题链接 很容易想到二维前缀和. 设\(S[i][j]\)表示矩阵\((0, 0)(i, j)\)内树木的棵数,则询问的矩形为\((x, y)(xx, yy)\)时,答案为\(S ...
- [SHOI2007]园丁的烦恼
裸的二维数点 #include"cstdio" #include"cstring" #include"iostream" #include& ...
- 【[SHOI2007]园丁的烦恼】
\(CDQ\) 分治的神奇操作 这个问题跟偏序问题好像差的不小啊 但是就是可以转化过去 对于一个查询我们可以把它拆成四个,也就是用二维前缀和的方式来查询 我们发现其实前缀和的定义就是多少个点的横纵坐标 ...
随机推荐
- 对于Python语音性能的一些个人见解
虽然运行速度慢是 Python 与生俱来的特点,大多数时候我们用 Python 就意味着放弃对性能的追求.但是,就算是用纯 Python 完成同一个任务,老手写出来的代码可能会比菜鸟写的代码块几倍,甚 ...
- sed命令总结
目录 1.概述 2.查 1.打印整行(一或多) 2.正则打印包含关键字的行 2.增 3.删 4.改 5.后向引用 6.结合 7.练习 我叫张贺,贪财好色.一名合格的LINUX运维工程师,专注于LINU ...
- 201871010108-高文利《面向对象程序设计(java)》第一周学习总结
项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址> ...
- 201871010113-刘兴瑞《面向对象程序设计(java)》第七周学习总结
项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址>htt ...
- 05_javaSE面试题:成员变量和局部变量
题目 /** * 类变量:static修饰的 * 实例变量:不是static修饰的 * * 局部变量:栈 * 实例变量:堆 * 类变量:方法区 * @author kevin * @date 2019 ...
- codeforces 1027E. Inverse Coloring(计数)
一开始发现的性质是确定了第一行后,后面的行只需要考虑和前面的行相同或者不同,整个过程只需要考虑行,构出的图一定符合性质(即同样满足列的性质),但是接下来死活定义不出状态,事实证明自己还是想的太少了 思 ...
- jenkins传统模式发布istio应用
一.发布金丝雀版本 Pre Setps cd /var/lib/jenkins/workspace/istio-service-user-canary/istio-service-user # 旧版本 ...
- python接口自动化6-参数化关联
前言 接口中我们经常需要用到参数关联,比如,登录token,需要传给后面的参数使用,又比如要查看某个商品需要将商品的id传入下一个接口使用. 等等,所以我们必要学会 re 正则获取,或者返回json获 ...
- 使用suds模块进行封装,处理webservice类型的接口
import json from suds.client import Client class HandleWebservice: ''' 定义一个webservice类型的接口处理类 ''' de ...
- nodejs通过钉钉群机器人推送消息
nodejs 通过钉钉群机器人推送消息 Intro 最近在用 nodejs 写爬虫,之前的 nodejs 爬虫代码用 js 写的,感觉可维护性太差,也没有智能提示,于是把js改用ts(typescri ...