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 ...
随机推荐
- document.domain
HTML DOM DOCUMENT 对象 定义和用法 domain 属性可返回下载当前文档的服务器域名. 语法 document.domain 说明 该属性是一个只读的字符串,包含了载入当前文档的 w ...
- webView和js交互
与 js 交互 OC 调用 JS // 执行 js - (void)webViewDidFinishLoad:(UIWebView *)webView { NSString *title = [web ...
- springboot + mysql 编写
1.springboot+mysql连接因为用的是hibernate框架,所以首先修改model,增加如下内容:
- git误删文件找回方法/git版本回退方法
使用git命令 git rm css/\*.css 我删掉了css文件夹下所有以.css结尾的文件,那么要怎样才能把文件找回来呢,下面说说方法,删掉其他的文件也是一样的方式找回. 第一步:使用git ...
- runtime-给系统已有类添加属性
在没有接触runtime之前,我们接触到的能给类进行扩展的方法有类目(category)和延展(extension)两种.类目(category)可以给系统已有类添加扩展方法但是不能添加属性,并且被添 ...
- 关于ie版本判断
//see: http://tanalin.com/en/articles/ie-version-js/ var browser = function(){ var isIE=!!window.Act ...
- Linux C++中的时间函数(转)
http://net.pku.edu.cn/~yhf/linux_c/function/03.html asctime(将时间和日期以字符串格式表示) 相关函数 time,ctime,gmtime ...
- codevs1257 打砖块
题目描述 Description 在一个凹槽中放置了n层砖块,最上面的一层有n块砖,第二层有n-1块,--最下面一层仅有一块砖.第i层的砖块从左至右编号为1,2,--i,第i层的第j块砖有一个价值a[ ...
- Matlab与Windows桌面提醒
最近在实验室用Matlab做实验,一次训练下来最少得也得5到10分钟吧.在Matlab运行的过程中,又不太好去做别的事情,因为5到10分钟的时间实在有点短.但是,眼睁睁看着代码的运行的话,5分钟又实在 ...
- tftp服务器简单安装配置
tftp服务器最简单安装配置 1.安装tftp-server sudo apt-get install tftpd-hpa sudo apt-get install tftp-hpa(如果不需要客户端 ...