Day6 - D - Tree 园丁的烦恼 HYSBZ - 1935
Sample Output3
思路:统计区间个数,想到二维树状数组,但数据太大无法开下,就选择离散化+偏序一维树状数组来进行二维树状数组的操作,将询问拆成4部分,就像二维树状数组一样
using namespace std;
#define lowbit(x) ((x)&(-x))
typedef long long LL; const int maxm = 5e5+; int x[maxm], y[maxm], a[maxm], b[maxm], c[maxm], d[maxm], n, m, tot, C[maxm], ally[maxm], ans[maxm][]; void add(int pos, int val) {
for(; pos <= tot; pos += lowbit(pos))
C[pos] += val;
} int getsum(int pos) {
int ret = ;
for(; pos; pos -= lowbit(pos))
ret += C[pos];
return ret;
} struct Node {
int x, y, id, val;
Node(){}
bool operator<(const Node &a) const {
return x < a.x || (x == a.x && val < a.val);
}
} Nodes[maxm*]; int main() {
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++i) {
scanf("%d%d", &x[i], &y[i]);
ally[++tot] = y[i];
}
for(int i = ; i <= m; ++i) {
scanf("%d%d%d%d", &a[i], &b[i], &c[i], &d[i]);
ally[++tot] = b[i], ally[++tot] = d[i];
}
sort(ally+, ally+tot+);
int len = unique(ally+, ally+tot+)-ally-;
int nodesum = ;
for(int i = ; i <= n; ++i) {
Nodes[nodesum].x = x[i], Nodes[nodesum++].y = lower_bound(ally+, ally++len, y[i]) - ally;
}
for(int i = ; i <= m; ++i) {
int ty1 = lower_bound(ally+, ally++len, d[i]) - ally, ty2 = lower_bound(ally+, ally++len, b[i]) - ally;
Nodes[nodesum].x = c[i], Nodes[nodesum].y = ty1, Nodes[nodesum].id = i, Nodes[nodesum++].val = ;
Nodes[nodesum].x = a[i]-, Nodes[nodesum].y = ty1, Nodes[nodesum].id = i, Nodes[nodesum++].val = ;
Nodes[nodesum].x = c[i], Nodes[nodesum].y = ty2-, Nodes[nodesum].id = i, Nodes[nodesum++].val = ;
Nodes[nodesum].x = a[i]-, Nodes[nodesum].y = ty2-, Nodes[nodesum].id = i, Nodes[nodesum++].val = ;
}
sort(Nodes, Nodes+nodesum);
for(int i = ; i < nodesum; ++i) {
if(!Nodes[i].val) {
add(Nodes[i].y, );
} else {
ans[Nodes[i].id][Nodes[i].val] = getsum(Nodes[i].y);
}
}
for(int i = ; i <= m; ++i)
printf("%d\n", ans[i][] - ans[i][] - ans[i][] + ans[i][]);
return ;
}
补:
这就是二维偏序问题,定一个序就变成一维统计问题,像CDQ分治也是,三维定一个序,变成二维问题,用CDQ,借助树状数组求和,本题x定序后,每一次求和都是0-x, 0-y,运用容斥拆成四个点,就无须再树状数组考虑x,只考虑y了
Day6 - D - Tree 园丁的烦恼 HYSBZ - 1935的更多相关文章
- BZOJ 1935: [Shoi2007]Tree 园丁的烦恼( 差分 + 离散化 + 树状数组 )
假如矩阵范围小一点就可以直接用二维树状数组维护. 这道题, 差分答案, 然后一维排序, 另一维离散化然后树状数组维护就OK了. ----------------------------------- ...
- 1935: [Shoi2007]Tree 园丁的烦恼
1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec Memory Limit: 357 MBSubmit: 648 Solved: 273[Submit][ ...
- bzoj1382 1935: [Shoi2007]Tree 园丁的烦恼
1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec Memory Limit: 357 MBSubmit: 1261 Solved: 578[Submit] ...
- BZOJ 1935: [Shoi2007]Tree 园丁的烦恼 +CDQ分治
1935: [Shoi2007]Tree 园丁的烦恼 参考与学习:https://www.cnblogs.com/mlystdcall/p/6219421.html 题意 在一个二维平面中有n颗树,有 ...
- [bzoj1935][shoi2007]Tree 园丁的烦恼(树状数组+离线)
1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec Memory Limit: 357 MBSubmit: 980 Solved: 450[Submit][ ...
- BZOJ1935: [Shoi2007]Tree 园丁的烦恼
1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec Memory Limit: 357 MBSubmit: 552 Solved: 220[Submit][ ...
- bzoj千题计划143:bzoj1935: [Shoi2007]Tree 园丁的烦恼
http://www.lydsy.com/JudgeOnline/problem.php?id=1935 二维偏序问题 排序x,离散化树状数组维护y #include<cstdio> #i ...
- [bzoj1935][Shoi2007]Tree 园丁的烦恼 _树状数组
Tree 园丁的烦恼 bzoj-1935 Shoi-2007 题目大意:给定平面上的$n$个点,$m$次查询矩形点个数. 注释:$1\le n,m\le 5\cdot 10^5$. 想法:静态二维数点 ...
- bzoj 1935: [Shoi2007]Tree 园丁的烦恼
Description 很久很久以前,在遥远的大陆上有一个美丽的国家.统治着这个美丽国家的国王是一个园艺爱好者,在他的皇家花园里种植着各种奇花异草.有一天国王漫步在花园里,若有所思,他问一个园丁道: ...
随机推荐
- jqgrid自适应宽度
https://blog.csdn.net/duzhanxiaosa/article/details/78922660
- 重新理解CEO的学习能力----HHR计划----以太入门课--第一课
一共5个小节. 第一节:开始学习 1,投资人最看重的一点:CEO的学习能力. (因为CEO需要:找优秀的合伙人,需要市场调研,机会判断,组建团队,验证方向,去融资,冷启动,做增长,解决法务,财务,税务 ...
- centos将uwsgi添加为系统服务
如果退出ssh 链接, 都会导致uwsgi进程关闭 这时, 我们需要进行管理软件管理uwsgi进行的运行, centos系统中我们采用 systemd, 让我们的项目变为系统服务 第一步: 首先 vi ...
- python3报:ImportError: No module named 'MySQLdb'
问题描述: 项目在转到python3.6时,原先的导入MySQLdb模块都提示无法导入,pip install mysqldb也安装失败. 问题原因: python2和python3在数据库模块支持这 ...
- 【PAT甲级】1006 Sign In and Sign Out (25 分)
题意: 给出学生人数M,输入M组学生ID,到机房的时间,离开机房的时间.输出最早到机房的学生的ID,空格,最后离开机房的学生的ID.(M大小未给出,就用了1e5) AAAAAccepted code: ...
- while语句及批量创建用户!
1.while 循环语句的作用:重复测试某个条件,只要条件成立则反复执行2.while 语句结构while 条件测试操作do命令序列done ============================= ...
- 使用IDEA查看数据库
emm...今天捣鼓了一下IDEA意外发现(原谅我后知后觉)不用Navicat也能查看数据库中的表,虽然可视化不如Navicat,但毕竟Navicat要钱,一些朋友也没有资源 = =,所以就记录并分享 ...
- Using webpack-dev-server
官方讲解地址:https://webpack.js.org/guides/development/#using-webpack-dev-server The webpack-dev-server pr ...
- 5.Nginx
1.Nginx 安装 (1) 安装gcc (yum install gcc) 备注:可以输入gcc -v 查询版本信息,看系统是否自带安装 (2) 安装pcre (yum install pcre-d ...
- PHP常用的一些优化技巧
PHP常用的一些优化技巧 点击联系老杨 ecshop模板 php 优化技巧 老杨ecshop ecshop二次开发 2013-03-29 0 做为最流行的WEB语言, PHP他的突出优势就是其速度与效 ...