题目大意:

题面传送门

三维偏序裸题

首先,把三元组关于$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+树状数组)的更多相关文章

  1. BZOJ 2141 排队 (三维偏序CDQ+树状数组)

    题目大意:略 洛谷传送门 和 [CQOI2015]动态逆序对 这道题一样的思路 一开始的序列视为$n$次插入操作 把每次交换操作看成四次操作,删除$x$,删除$y$,加入$x$,加入$y$ 把每次操作 ...

  2. Luogu 3810 & BZOJ 3262 陌上花开/三维偏序 | CDQ分治

    Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...

  3. BZOJ 2716/2648 SJY摆棋子 (三维偏序CDQ+树状数组)

    题目大意: 洛谷传送门 这明明是一道KD-Tree,CDQ分治是TLE的做法 化简式子,$|x1-x2|-|y1-y2|=(x1+y1)-(x2+y2)$ 而$CDQ$分治只能解决$x1 \leq x ...

  4. BZOJ 1176/2683 Mokia (三维偏序CDQ+树状数组)

    题目大意: 洛谷传送门 三维偏序裸题.. 每次操作都看成一个三元组$<x,y,t>$,表示$x,y$坐标和操作时间$t $ 询问操作拆成$4$个容斥 接下来就是$CDQ$了,外层按t排序, ...

  5. BZOJ 3295 [CQOI2011]动态逆序对 (三维偏序CDQ+树状数组)

    题目大意: 题面传送门 还是一道三维偏序题 每次操作都可以看成这样一个三元组 $<x,w,t>$ ,操作的位置,权值,修改时间 一开始的序列看成n次插入操作 我们先求出不删除时的逆序对总数 ...

  6. bzoj3262陌上花开 三维数点 cdq+树状数组

    大早上的做了一道三维数点一道五位数点,神清气爽! 先给一维排序,变成一个奇怪的动态的二维数点(相当于有一个扫描面扫过去,导致一系列的加点和询问) 然后cdq分治,再变回静态,考虑前半段对后半段的影响 ...

  7. 洛谷P3810-陌上开花(三维偏序, CDQ, 树状数组)

    链接: https://www.luogu.org/problem/P3810#submit 题意: 一个元素三个属性, x, y, z, 给定求f(b) = {ax <= bx, ay < ...

  8. bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组

    [bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ...

  9. bzoj3262: 陌上花开(CDQ+树状数组处理三维偏序问题)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3262 题目大意:中文题目 具体思路:CDQ可以处理的问题,一共有三维空间,对于第一维我们 ...

随机推荐

  1. [SDOI2016]数字配对(费用流+贪心+trick)

    重点是如何找到可以配对的\(a[i]\)和\(a[j]\). 把\(a[i]\)分解质因数.设\(a[i]\)分解出的质因数的数量为\(cnt[i]\). 设\(a[i]\geq a[j]\) 那么\ ...

  2. win主机ping不通linux的IP

    1.虚拟机的中的linux系统设置成桥接模式 2.点击虚拟机的编辑选择虚拟网络编辑器 3.点击更改设置 4点击还原默认设置即可

  3. 搞定PHP面试 - 深入了解引用

    1. 什么是引用 在 PHP 中引用是指用不同的名字访问同一个变量内容.PHP 中的变量名和变量内容是不一样的, 因此同样的内容可以有不同的名字.最接近的比喻是 Unix 的文件名和文件本身--变量名 ...

  4. EXPLAIN sql优化方法(3)DERIVED

    派生表和视图的性能 从MySQL 4.1开始,它已经支持派生表.联机视图或者基本的FROM从句的子查询. 这些特性之间彼此相关,但是它们之间的性能比较如何呢? MySQL 5.0 中的派生表似乎和视图 ...

  5. Ajax接收json响应

    json?  Json和xml比较  Ajax如何使用JSON  Ajax接收json响应案例 什么是json?JSON (JavaScript Object Notation) 是一种轻量级的 ...

  6. A - Jungle Roads

    A - Jungle Roads 思路:并查集的板子,重点是字符的转换,不能忘了加上1. #include<cmath> #include<cstdio> #include&l ...

  7. Android获取图片实际大小兼容平板电脑

    项目中有个图片在平板电脑中显示特别小的原因.一直苦于没找到原因,也没有平板电脑測试,今天找了个改动分辨率的,编写相关方法最终处理了,记录下比較: 好让以后不造轮子. 主要是获取文章相关图片显示问题.直 ...

  8. Swift入门(四)——可选类型(Optionals)与断言(Assert)

    可选类型是什么? 首先看一个问题,Swift中String类型的变量有一个叫做toInt的方法,能够把String类型变量转换为Int类型变量. var stringValue = "5&q ...

  9. hibernate 管理 Session(单独使用session,非spring)

    Hibernate 自身提供了三种管理 Session 对象的方法 Session 对象的生命周期与本地线程绑定 Session 对象的生命周期与 JTA 事务绑定 Hibernate 托付程序管理 ...

  10. Mysql中You can't specify target table for update in FROM clause错误的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中)。

    将select出的结果再通过中间表select一遍,这样就规避了错误.注意,这个问题只出现于mysql,mssql和oracle不会出现此问题. mysql中You can't specify tar ...