BZOJ 3262 陌上花开 (三维偏序CDQ+树状数组)
题目大意:
三维偏序裸题
首先,把三元组关于$a_{i}$排序
然后开始$CDQ$分治,回溯后按$b_{i}$排序
现在要处理左侧对右侧的影响了,显然现在左侧三元组的$a_{i}$都小于等于右侧
而$c_{i}$这一维需要用权值树状数组维护
归并排序时,已知左侧右侧两个指针分别是$i,j$
如果$b_{i} \leq bj$,将左侧已经遍历过的三元组的$c_{i}$推入树状数组,然后$i++$
如果$b_{i}>bj$,那么右侧能取到的贡献就是树状数组内$\leq c_{j}$的三元组数量,然后$j++$
可三元组有重复的啊!
如果我们不去重,假设有两个相同的三元组,靠前的三元组会得不到后面的贡献
还需要去重,并额外记录相同三元组数量
这道题的判定条件三个元是小于等于
发现我们只关于$a_{i}$排序也不行啊
在归并过程中会发现有一些$b_{i}$或者是$c_{i}$明明比较大,却得不到后面较小的贡献
这是由于小于等于的情况也合法,而我们必须让较大的在后面,才能保证后面能取到前面的贡献
所以排序过程中第二维还要按$b_{i}$排序,第三维按$c_{i}$
#include <vector>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N1 100100
#define ll long long
#define dd double
#define inf 0x3f3f3f3f3f3f3f3fll
using namespace std; int gint()
{
int ret=,fh=;char c=getchar();
while(c<''||c>''){if(c=='-')fh=-;c=getchar();}
while(c>=''&&c<=''){ret=ret*+c-'';c=getchar();}
return ret*fh;
}
int n,nn,K;
struct node{
int id,num,a,b,c;
friend bool operator == (const node &s1,const node &s2)
{return (s1.a==s2.a)&&(s1.b==s2.b)&&(s1.c==s2.c);}
friend bool operator < (const node &s1,const node &s2)
{
if(s1.a!=s2.a) return s1.a<s2.a;
if(s1.b!=s2.b) return s1.b<s2.b;
return s1.c<s2.c;
}
}p[N1],t[N1],tmp[N1]; struct b_{i}T{
int s[N1<<];
void update(int x,int w){for(int i=x;i<=K;i+=(i&(-i))) s[i]+=w;}
int query(int x){int ans=; for(int i=x;i>;i-=(i&(-i))) ans+=s[i]; return ans;}
}b;
int f[N1],hs[N1],que[N1],tl;
void CDQ(int L,int R)
{
if(R-L<=) return;
int M=(L+R)>>;
CDQ(L,M); CDQ(M,R);
int i=L,j=M,cnt=;
while(i<M&&j<R)
{
if(t[i].b<=t[j].b){
b.update(t[i].c,t[i].num);
tmp[++cnt]=t[i]; i++; que[++tl]=cnt;
}else{
f[t[j].id]+=b.query(t[j].c);
tmp[++cnt]=t[j]; j++;
}
}
while(i<M){tmp[++cnt]=t[i]; i++;}
while(j<R){f[t[j].id]+=b.query(t[j].c); tmp[++cnt]=t[j]; j++;}
while(tl) i=que[tl--],b.update(tmp[i].c,-tmp[i].num);
for(i=L;i<R;i++) t[i]=tmp[i-L+];
} int main()
{
scanf("%d%d",&n,&K);
int i;
for(i=;i<=n;i++) p[i].a=gint(),p[i].b=gint(),p[i].c=gint();
sort(p+,p+n+);
for(i=;i<=n;i++)
if(!(p[i]==p[i-])) t[++nn]=p[i],t[nn].num=;
else t[nn].num++;
for(i=;i<=nn;i++) t[i].id=i;
CDQ(,nn+);
for(i=;i<=nn;i++) hs[f[t[i].id]+t[i].num-]+=t[i].num;
for(i=;i<n;i++) printf("%d\n",hs[i]);
return ;
}
BZOJ 3262 陌上花开 (三维偏序CDQ+树状数组)的更多相关文章
- BZOJ 2141 排队 (三维偏序CDQ+树状数组)
题目大意:略 洛谷传送门 和 [CQOI2015]动态逆序对 这道题一样的思路 一开始的序列视为$n$次插入操作 把每次交换操作看成四次操作,删除$x$,删除$y$,加入$x$,加入$y$ 把每次操作 ...
- Luogu 3810 & BZOJ 3262 陌上花开/三维偏序 | CDQ分治
Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...
- BZOJ 2716/2648 SJY摆棋子 (三维偏序CDQ+树状数组)
题目大意: 洛谷传送门 这明明是一道KD-Tree,CDQ分治是TLE的做法 化简式子,$|x1-x2|-|y1-y2|=(x1+y1)-(x2+y2)$ 而$CDQ$分治只能解决$x1 \leq x ...
- BZOJ 1176/2683 Mokia (三维偏序CDQ+树状数组)
题目大意: 洛谷传送门 三维偏序裸题.. 每次操作都看成一个三元组$<x,y,t>$,表示$x,y$坐标和操作时间$t $ 询问操作拆成$4$个容斥 接下来就是$CDQ$了,外层按t排序, ...
- BZOJ 3295 [CQOI2011]动态逆序对 (三维偏序CDQ+树状数组)
题目大意: 题面传送门 还是一道三维偏序题 每次操作都可以看成这样一个三元组 $<x,w,t>$ ,操作的位置,权值,修改时间 一开始的序列看成n次插入操作 我们先求出不删除时的逆序对总数 ...
- bzoj3262陌上花开 三维数点 cdq+树状数组
大早上的做了一道三维数点一道五位数点,神清气爽! 先给一维排序,变成一个奇怪的动态的二维数点(相当于有一个扫描面扫过去,导致一系列的加点和询问) 然后cdq分治,再变回静态,考虑前半段对后半段的影响 ...
- 洛谷P3810-陌上开花(三维偏序, CDQ, 树状数组)
链接: https://www.luogu.org/problem/P3810#submit 题意: 一个元素三个属性, x, y, z, 给定求f(b) = {ax <= bx, ay < ...
- bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组
[bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ...
- bzoj3262: 陌上花开(CDQ+树状数组处理三维偏序问题)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3262 题目大意:中文题目 具体思路:CDQ可以处理的问题,一共有三维空间,对于第一维我们 ...
随机推荐
- nyoj254-编号统计
编号统计 时间限制:2000 ms | 内存限制:65535 KB 难度:2 描述 zyc最近比较无聊,于是他想去做一次无聊的统计一下.他把全校同学的地址都统计了一下(zyc都将地址转化成了编码) ...
- bitset骚操作
bitset的用途挺多的,是一个比较骚的常数优化 一.很多位数的二进制数 poj 2443 http://poj.org/problem?id=2443 直接开个1万位的二进制数,求交就行了. 有关集 ...
- ElasticSearch[v6.2] 在实际项目中的应用
摘要:本文所讲述的内容,为ElasticSearch(以下简称ES)全文搜索引擎在实际大数据项目的应用:ES的底层是开源库 Lucene.但是,你没法直接用 Lucene,必须自己写代码去调用它的接口 ...
- spring boot系列--spring security (基于数据库)登录和权限控制
先说一下AuthConfig.java Spring Security的主要配置文件之一 AuthConfig 1 @Configuration 2 @EnableWebSecurity 3 publ ...
- void型指针
void型指针,表示这个指针指向的内存中的数据的类型要由用户来指定. 比方内存分配函数malloc函数返回的指针就是void *型. 用户在使用这个指针的时候.要进行强制类型转换,也就是显式说明该指针 ...
- 自己定义Android Dialog
private void showDialog() { mDialog = new Dialog(this); mDialog.setCanceledOnTouchOutside(true); Win ...
- Mina airQQ聊天 client篇(三)
开发工具 (FlashBuilder4.7) 程序类型(Adobe Air) Flex Air做的桌面程序,效果还挺好看的.最主要是Socket这一块,它也是异步的,而且在Flex中的事件机制比較强大 ...
- 【POJ 2942】Knights of the Round Table(双联通分量+染色判奇环)
[POJ 2942]Knights of the Round Table(双联通分量+染色判奇环) Time Limit: 7000MS Memory Limit: 65536K Total Su ...
- openssl之EVP系列之2---对称加密算法概述
openssl之EVP系列之2---对称加密算法概述 ---依据openssl doc/crypto/EVP_EncryptInit.pod和doc/ssleay.txt cipher.doc ...
- BZOJ 3323 splay维护序列
就第三个操作比较新颖 转化成 在l前插一个点 把r和r+1合并 //By SiriusRen #include <cstdio> #include <cstring> #inc ...