#include <iostream>
#include <stdio.h>
#include <algorithm>
using namespace std; const int maxn=1e5+10;
const int maxk=2e5+10; int n,k; struct Triple {
int a,b,c,cnt,ans;
}a[maxn],A[maxn]; bool cmp(const Triple &a,const Triple &b) {
if (a.a!=b.a) {
return a.a<b.a;
}
else if (a.b!=b.b) {
return a.b<b.b;
}
return a.c<b.c;
} struct BitIndexTree {
int a[maxk]; int lowbit(const int x) {
return x&(-x);
} void Update(const int x,const int delta) {
for (int i=x;i<=k;i+=lowbit(i)) {
a[i]+=delta;
}
} void Clean(const int x) {
for (int i=x;i<=k;i+=lowbit(i)) {
if (a[i]) {
a[i]=0;
}
else {
break;
}
}
} int Query(const int x) {
int ans=0;
for (int i=x;i>0;i-=lowbit(i)) {
ans+=a[i];
}
return ans;
}
}bit; void CDQ(Triple *l,Triple *r)
{
if (l==r) {
l->ans+=l->cnt-1;
return ;
}
Triple *mid=l+(r-l)/2;
CDQ(l,mid);
CDQ(mid+1,r); static Triple tmp[maxn];
for (Triple *p=tmp,*p1=l,*p2=mid+1;p<=tmp+(r-l);p++) {
if ((p1<=mid&&p1->b<=p2->b)||p2>r) {
*p=*p1++;
bit.Update(p->c,p->cnt);
}
else {
*p=*p2++;
p->ans+=bit.Query(p->c);
}
}
for (Triple *p=tmp,*q=l;q<=r;p++,q++) {
bit.Clean(p->c);
*q=*p;
}
} template <typename T>
inline void read(T &x)
{
int f=1;
x=0;
register char ch;
ch=getchar();
while (ch>'9'||ch<'0') {
if (ch=='-') {
f=-f;
}
ch=getchar();
}
while (ch>='0'&&ch<='9') {
x=x*10+ch-'0';
ch=getchar();
}
x*=f;
} inline void write(int x)
{
if (x<0) {
putchar('-');
}
if (x>9) {
write(x/10);
}
putchar(x%10+'0');
} int main()
{
scanf("%d%d",&n,&k);
for (int i=0;i<n;i++) {
read(a[i].a),read(a[i].b),read(a[i].c);
// scanf("%d%d%d",&a[i].a,&a[i].b,&a[i].c);
a[i].cnt=1;
}
sort(a,a+n,cmp);
int cnt=0;
for (int i=0;i<n;i++) {
if (i==0||!(a[i].a==a[i-1].a&&a[i].b==a[i-1].b&&a[i].c==a[i-1].c)) {
A[cnt++]=a[i];
}
else {
A[cnt-1].cnt+=1;
}
}
CDQ(A,A+cnt-1);
static int ans[maxn];
for (int i=0;i<cnt;i++) {
ans[A[i].ans]+=A[i].cnt;
}
for (int i=0;i<n;i++) {
write(ans[i]);
putchar('\n');
// printf("%d\n",ans[i]);
}
return 0;
}

BZOJ 3262: 陌上花开 (cdq分治,三维偏序)的更多相关文章

  1. BZOJ 3262: 陌上花开 [CDQ分治 三维偏序]

    Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...

  2. bzoj 3262 陌上花开 - CDQ分治 - 树状数组

    Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...

  3. 洛谷P3810 陌上花开 CDQ分治(三维偏序)

    好,这是一道三维偏序的模板题 当然没那么简单..... 首先谴责洛谷一下:可怜的陌上花开的题面被无情的消灭了: 这么好听的名字#(滑稽) 那么我们看了题面后就发现:这就是一个三维偏序.只不过ans不加 ...

  4. BZOJ 3262 陌上花开 ——CDQ分治

    [题目分析] 多维问题,我们可以按照其中一维排序,然后把这一维抽象的改为时间. 然后剩下两维,就像简单题那样,排序一维,树状数组一维,按照时间分治即可. 挺有套路的一种算法. 时间的抽象很巧妙. 同种 ...

  5. BZOJ 3262 陌上花开 CDQ分治

    = =原来复杂度还是nlog^2(n) Orz 被喷了 #include<cstdio> #include<cstdlib> #include<algorithm> ...

  6. BZOJ - 1935 / 1176 cdq分治 三维偏序

    题意:给定n*m的网格,且给出n个(x,y)表示该网格已被占有,q次询问(x1,y1)到(x2,y2)的网格中有多少个被占有,n,m范围1e7,q范围5e5 cdq按x轴排序,树状数组维护y轴 #in ...

  7. BZOJ 2244: [SDOI2011]拦截导弹 (CDQ分治 三维偏序 DP)

    题意 略- 分析 就是求最长不上升子序列,坐标取一下反就是求最长不下降子序列,比较大小是二维(h,v)(h,v)(h,v)的比较.我们不看概率,先看第一问怎么求最长不降子序列.设f[i]f[i]f[i ...

  8. cdq分治·三维偏序问题

    转载自FlashHu大佬的博客CDQ分治总结(CDQ,树状数组,归并排序),在讲述部分有部分删改,用了自己的代码 CDQ分治的思想 CDQ分治是基于时间的离线分治算法.这一类分治有一个重要的思想——用 ...

  9. 【算法】CDQ分治 -- 三维偏序 & 动态逆序对

    初次接触CDQ分治,感觉真的挺厉害的.整体思路即分而治之,再用之前处理出来的答案统计之后的答案. 大概流程是(对于区间 l ~ r): 1.处理 l ~mid, mid + 1 ~ r 的答案: 2. ...

随机推荐

  1. 嵌入式Linux学习---进程(1)

    什么是一个进程?当用户敲入命令执行一个程序的时候,对系统而言,它将启动一个进程.但和程序不同的是,在这个进程中,系统可能需要再启动一个或多个进程来完成独立的多个任务.多进程编程的主要内容包括进程控制和 ...

  2. 2019杭电多校 permutation2

    Problem:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1007&cid=852 #include<bits ...

  3. Java Web代码审计流程与漏洞函数

    常见框架与组合 常见框架 Struts2 SpringMVC Spring Boot 框架执行流程 View层:视图层 Controller层:表现层 Service层:业务层 Dom层:持久层 常见 ...

  4. 174. 地下城游戏(逆向DP)

    Q: 一些恶魔抓住了公主(P)并将她关在了地下城的右下角.地下城是由 M x N 个房间组成的二维网格.我们英勇的骑士(K)最初被安置在左上角的房间里,他必须穿过地下城并通过对抗恶魔来拯救公主. 骑士 ...

  5. JQ DOM元素 创建 添加 删除

    创建元素 // 创建元素节点 $('<p></p>'); // 创建属性节点 $('<p class="wow"></p>'); / ...

  6. C++-POJ1015-Jury Compromise

    Java实现会MLE那我也没办法了 //辩方总分和控方总分之差简称为“辩控差” //辩方总分和控方总分之和简称为“辩控和” //现用f(j, k)表示,取j 个候选人,使其辩控差为k 的所有方案中,辩 ...

  7. Java-POJ1006-Biorhythms(中国剩余定理)

    https://blog.csdn.net/shanshanpt/article/details/8724769 有中文题面,就不解释了. 妥妥的中国剩余定理没跑了. Java跑得慢,一点办法也没有, ...

  8. 洛谷P1118 [USACO06FEB]数字三角形`Backward Digit Su`…

    #include<iostream> using namespace std ; ; int y[N][N]; int n; int a[N]; bool st[N]; int sum; ...

  9. centos安装虚拟机,桥接网络连接失败

    centos安装虚拟机,桥接网络连接失败 待办 即使是虚拟机也要在网络选择网桥连接方式之后,点击连接网线才可以,虚拟机都是按照有线进行连接的.

  10. CF1288F Red-Blue Graph

    Link 考虑上下界+费用流. 对于左部点\(u\): 如果颜色为\(B\),连\((s,u,[1,+\infty),0)\). 如果颜色为\(R\),连\((u,t,[1,+\infty),0)\) ...