安利系列博文

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]园丁的烦恼的更多相关文章

  1. [LuoguP2163][SHOI2007]园丁的烦恼_CDQ分治

    园丁的烦恼 题目链接:https://www.luogu.org/problem/P2163 数据范围:略. 题解: 树套树过不去,那就$CDQ$分治好了. 有点小细节,但都是$CDQ$分治必要的. ...

  2. P2163 [SHOI2007]园丁的烦恼

    题目 P2163 [SHOI2007]园丁的烦恼 做法 关于拆点,要真想拆直接全部用树状数组水过不就好了 做这题我们练一下\(cdq\)分治 左下角\((x1,y1)\)右上角\((x2,y2)\), ...

  3. bzoj1935 [Shoi2007]园丁的烦恼

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

  4. 洛谷 P2163 [SHOI2007]园丁的烦恼 (离线sort,树状数组,解决三维偏序问题)

    P2163 [SHOI2007]园丁的烦恼 题目描述 很久很久以前,在遥远的大陆上有一个美丽的国家.统治着这个美丽国家的国王是一个园艺爱好者,在他的皇家花园里种植着各种奇花异草. 有一天国王漫步在花园 ...

  5. P2163 【[SHOI2007]园丁的烦恼】

    其实是不用把一个询问拆成四个的 把询问转化为数学语言: 对于每个查询,询问满足$a<=x<=b$且$c<=y<=d$的点$x,y$的个数 ~~自然~~想到偏序问题,看到有两个式 ...

  6. P2163 [SHOI2007]园丁的烦恼(cdq分治)

    思路 其实是cdq的板子 题目要求询问对于每个给出的xi,yi,xj,yj形如xi<=x<=xj.yi<=y<=yj的x,y对数有多少组 改成四个询问,拆成四个前缀和的形式后就 ...

  7. BZOJ1935或洛谷2163 [SHOI2007]园丁的烦恼

    BZOJ原题链接 洛谷原题链接 很容易想到二维前缀和. 设\(S[i][j]\)表示矩阵\((0, 0)(i, j)\)内树木的棵数,则询问的矩形为\((x, y)(xx, yy)\)时,答案为\(S ...

  8. [SHOI2007]园丁的烦恼

    裸的二维数点 #include"cstdio" #include"cstring" #include"iostream" #include& ...

  9. 【[SHOI2007]园丁的烦恼】

    \(CDQ\) 分治的神奇操作 这个问题跟偏序问题好像差的不小啊 但是就是可以转化过去 对于一个查询我们可以把它拆成四个,也就是用二维前缀和的方式来查询 我们发现其实前缀和的定义就是多少个点的横纵坐标 ...

随机推荐

  1. bay——安装_Oracle 12C-单实例-Centos7 -DG.txt

    用户和密码: root/bayaimbayaim/064286BAIbayoracle/oracleSID:orclsys/oraclesystem/oraclempay/mpaydx/dx ---- ...

  2. Linux-3.14.12内存管理笔记【伙伴管理算法(2)】

    前面已经分析了linux内存管理算法(伙伴管理算法)的准备工作. 具体的算法初始化则回到start_kernel()函数接着往下走,下一个函数是mm_init(): [file:/init/main. ...

  3. centos图形化桌面安装过程

    连接 1.安装xwindow yum -y groupinstall "X Window System" \\安装 X Window System 环境 2.安装gnome des ...

  4. 关于一道fork生成子进程的题目

    题目如下: pid_t pid1,pid2; pid1=fork(); pid2=fork(); ||pid2<) { printf("Fork Failed\n"); } ...

  5. leetcode——动态规划

    立志要熟练动态规划,加油! 最长回文子串给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 思路:设dp[l][r]表示s[l……r]是否回文,枚举右边界r,然后 ...

  6. WinFrom和WebFrom的区别

    原文链接:https://blog.csdn.net/sloder/article/details/6145169 一是Winform的定位机制没有Webform丰富,web里有table,div(浮 ...

  7. LeetCode 1255 得分最高的单词集合 Maximum Score Words Formed by Letters

    地址 https://leetcode-cn.com/problems/maximum-score-words-formed-by-letters/ 题目描述你将会得到一份单词表 words,一个字母 ...

  8. Sigma Function (LightOJ - 1336)【简单数论】【算术基本定理】【思维】

    Sigma Function (LightOJ - 1336)[简单数论][算术基本定理][思维] 标签: 入门讲座题解 数论 题目描述 Sigma function is an interestin ...

  9. IT人的立功,立言,立德三不朽

    最近几个月很忙,忙着当奶爸,忙着做加班狗,忙着补裤裆学技术……以至于快忘了要思考人生了! 古人立志穷极一生追求“立德”,“立功”,“立言”,以求不朽,为万世所景仰,为后人所传颂,实现人生的意义.立德者 ...

  10. Codeforces Round #594 (Div. 1) A. Ivan the Fool and the Probability Theory 动态规划

    A. Ivan the Fool and the Probability Theory Recently Ivan the Fool decided to become smarter and stu ...