CDQ学习笔记
CDQ三维偏序
给出n个点(x,y,z)
每个点求出x'<=x,y'<=x,z'<=x的点(x',y',z')有多少个
第一维 快排 第二维 CDQ 第三维 树状数组
CDQ
先按x第一关键字,y第二关键字,z第三关键字快排
CDQ先处理左半边,再处理右半边
现在满足左半边的x全部小于右半边的x
那就只用考虑y,z
将左半边的y排序,右半边的y排序
像two-pionter那样扫一下用树状数组维护z
为了节省时间不清空树状数组开个时间戳
对于相等权值需要特判的,cdq全部算完之后再按一开始那样快排
从后往前扫一遍用后面的更新前面
快排
wa了7发,第一次知道快排是左闭右开区间
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
using namespace std;
typedef long long LL;
const int M=100007;
inline int rd(){
int x;
scanf("%d",&x);
return x;
}
int tcas;
int n;
int ans[M];
int tms[M];
int c[M];
int T;
struct node{
int x,y,z,id,dp;
void input(int ii){x=rd(),y=rd(),z=rd(),id=ii;dp=0;}
}a[M];
bool operator ==(node x,node y){
return x.x==y.x&&x.y==y.y&&x.z==y.z;
}
bool cmp(node x,node y){
if(x.x==y.x&&x.y==y.y)return x.z<y.z;
if(x.x==y.x)return x.y<y.y;
return x.x<y.x;
}
bool cmpx(node x,node y){return x.x<y.x;}
bool cmpy(node x,node y){return x.y<y.y;}
inline int lb(int x){return x&(-x);}
void ins(int x,int d){
for(;x<M;x+=lb(x)){
if(tms[x]!=T) {c[x]=0;tms[x]=T;}
c[x]+=d;
}
}
int get(int x){
int res=0;
for(;x>0;x-=lb(x)){
if(tms[x]==T) res+=c[x];
}
return res;
}
void calc(int l,int r){
if(l==r)return;
int i,j,mid=l+r>>1;
calc(l,mid);
calc(mid+1,r);
sort(a+l,a+mid+1,cmpy);
sort(a+mid+1,a+r+1,cmpy);
T++;
for(i=l,j=mid+1;j<=r;j++){
for(;a[i].y<=a[j].y&&i<=mid;i++){
ins(a[i].z,1);
}
a[j].dp+=get(a[j].z);
}
}
int main(){
int i;
tcas=rd();
while(tcas--){
n=rd();
for(i=1;i<=n;i++) a[i].input(i);
sort(a+1,a+n+1,cmp);
calc(1,n);
sort(a+1,a+n+1,cmp);
for(i=n-1;i>0;i--) if(a[i]==a[i+1]) a[i].dp=a[i+1].dp;
for(i=1;i<=n;i++) ans[a[i].id]=a[i].dp;
for(i=1;i<=n;i++) printf("%d\n",ans[i]);
}
return 0;
}
CDQ学习笔记的更多相关文章
- CDQ 学习笔记
CDQ分治 CDQ(陈丹琦)分治是一种特殊的分治方法. 它只能处理非强制在线的问题. CDQ分治在维护一些动态的凸包.半平面交问题也有一定应用,然而本渣渣并不会. CDQ分治基于时间分治,整体二分基于 ...
- 学习笔记 | CDQ分治
目录 前言 啥是CDQ啊(它的基本思想) 例题 后记 参考博文 前言 博主太菜了 学习快一年的OI了 好像没有什么会的算法 更寒碜的是 学一样还不精一样TAT 如有什么错误请各位路过的大佬指出啊感谢! ...
- OI知识点|NOIP考点|省选考点|教程与学习笔记合集
点亮技能树行动-- 本篇blog按照分类将网上写的OI知识点归纳了一下,然后会附上蒟蒻我的学习笔记或者是我认为写的不错的专题博客qwqwqwq(好吧,其实已经咕咕咕了...) 基础算法 贪心 枚举 分 ...
- 【框架】Django入门学习笔记
教程 Demo 教材2 教材3 [转] Django处理请求的工作机制 记住: 1.用manage.py runserver 启动Django服务器时就载入了在同一目录下的settings.py.该文 ...
- 【学习笔记】动态规划—斜率优化DP(超详细)
[学习笔记]动态规划-斜率优化DP(超详细) [前言] 第一次写这么长的文章. 写完后感觉对斜优的理解又加深了一些. 斜优通常与决策单调性同时出现.可以说决策单调性是斜率优化的前提. 斜率优化 \(D ...
- KD-Tree 学习笔记
这是一篇又长又烂的学习笔记,请做好及时退出的准备. KD-Tree 的复杂度大概是 \(O(n^{1-\frac{1}{k}})\) \(k\) 是维度 由于网上找不到靠谱的证明,咕了. 会证明之后再 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
随机推荐
- 【BZOJ-4380】Myjnie 区间DP
4380: [POI2015]Myjnie Time Limit: 40 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 162 Solved: ...
- Web应用请求和响应 HTTP相关
(1)请求:浏览器以HTTP协议的方式提交请求到服务器 (2)响应:服务器以HTTP协议的方式响应内容到浏览器 注意:HTTP是WEB大众化非安全协议 HTTPS是WEB安全协议,是基于HTTP协议的 ...
- SpringCloud: 服务发现
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #e4af0a } sp ...
- 【原创】自己动手写工具----XSmartNote [Beta 2.0]
一.前面的话 在上一篇自己动手写工具----XSmartNote中,我简单介绍了这个小玩意儿的大致界面和要实现的功能,看了一下园子里的评论,评价褒贬不一,有人说“现在那么多云笔记的工具”,“极简版ev ...
- Python学习总结 03 Plotly 学习总结
一 Plotly 简介 Plotly是另一个免费进行数据分析和绘制图表的APP,建立在d3.js上. Plotly图可下载为SVG,EPS或PNG格式,并简单地导入到Illustrator或者Phot ...
- 解决SmartGit序列号问题
SmartGit过了30天试用期之后,就需要用户输入序列号才能继续使用,有一个办法可以跳过输入序列号. 一.windows+R 输入:%APPDATA%\syntevo\SmartGit 二.打开7 ...
- ITShare
框架底层通过IBatis和XML实现ORM映射: 业务处理类似UI,通过Controller和JavaScript交互: 视图通过Castle与NVelocity实现,jquery.tmpl渲染: . ...
- C++类成员在内存中的存储及对齐方式
前言:数据对齐的基本理论参见文章:http://www.cnblogs.com/MyBlog-Richard/articles/5993448.html 一.空类的大小 C++中空类的大小是1,这是因 ...
- Fedora中显示windows下的文件
目录 一些预备知识: 在中国windows的编码是本地编码 , 即GBK,GB2312,GB18030等 GBK 也就是windows-986 Windows现在只支持Unicode (UTF-16 ...
- 101 LINQ Samples
https://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b