求三维偏序

设三维为a,b,c。先对a排序,这样i的偏序就只能<i。

然而排序的时候需要三个维度都判断一遍,最后还要去重,不然会出现实际应该记答案的数出现在它后面的情况。

(排序用的函数里不要写类似于<=之类的东西啊..会出奇奇怪怪的问题的(RE))

然后分治来做,我们在做区间[l,r]的时候,先去做[l,m]和[m+1,r]

之后左区间[l,m],右区间[m+1,r]都已经按照b排好序了,而且左右两区间内部的答案已经统计过了,所以现在只要考虑左区间中满足(右区间的数)的数量就好了。

那么就也把[l,r]按照b排好序,在排的时候再用一个权值树状数组维护c,

也就是,如果这个点是左区间的点,就把它的c值对应的树状数组中+=这个点的重复数(刚才去重了)

    如果这个点是右区间的点,就询问树状数组中<=它的c值的数量,然后加到这个点的答案里。

而且每次做的时候树状数组都要清空,但不能用memset来清,复杂度有问题。(一直迷信memset的速度,结果一查告诉我也就比循环清快一倍??)

所以只要把刚才加过的再减回去就可以了。

复杂度$O(n*log_2n*log_2k)$

也可以cdq套cdq,然后不用树状数组,复杂度是一样的。

这样一直套下去,k维的话复杂度也就是$O(n*log^{k-1}_2n)$啦

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#include<cmath>
#include<ctime>
#define LL long long int
#define inf 0x3f3f3f3f
#define lowbit(x) ((x)&(-(x)))
using namespace std;
const int maxn=,maxk=; LL rd(){
LL x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} struct Node{
int a,b,c,i;
}inp[maxn],num[maxn],tmp[maxn];
int iniN,N,K;
int tr[maxk],cnt[maxn],siz[maxn],ans[maxn]; inline bool cmp(Node a,Node b){return a.a==b.a?(a.b==b.b?a.c<b.c:a.b<b.b):a.a<b.a;} inline void add(int x,int y){
while(x&&x<=K) tr[x]+=y,x+=lowbit(x);
}
inline int query(int x){
int re=;while(x) re+=tr[x],x-=lowbit(x);return re;
} void cdq(int l,int r){
int m=l+r>>,p=l,q=m+,t=;
if(l>=r) return;
cdq(l,m);cdq(m+,r);
while(p<=m&&q<=r){
if(num[p].b<=num[q].b){
tmp[++t]=num[p];add(num[p].c,siz[num[p].i]);p++;
}else{
tmp[++t]=num[q];cnt[num[q].i]+=query(num[q].c);q++;
}
} while(q<=r){
tmp[++t]=num[q];cnt[num[q].i]+=query(num[q].c);q++;
}for(int i=l;i<p;i++) add(num[i].c,-siz[num[i].i]);
while(p<=m) tmp[++t]=num[p++]; memcpy(num+l,tmp+,sizeof(Node)*t);
} int main(){
int i,j,k;
iniN=N=rd();K=rd();
for(i=;i<=N;i++){
int a=rd(),b=rd(),c=rd();
inp[i].a=a;inp[i].b=b;inp[i].c=c;num[i].i=i;
}
sort(inp+,inp+N+,cmp);//printf("ll");
for(i=,j=;i<=N;i++){
if(inp[i].a==inp[i-].a&&inp[i].b==inp[i-].b&&inp[i].c==inp[i-].c) inp[i].i=j,cnt[j]++,siz[j]++;
else{
inp[i].i=++j;num[j]=inp[i];siz[j]=;
}
}N=j;
cdq(,N);
for(i=;i<=N;i++) ans[cnt[i]]+=siz[i];
for(i=;i<iniN;i++) printf("%d\n",ans[i]);
return ;
}

luogu3810 陌上花开 (cdq分治)的更多相关文章

  1. P3810 陌上花开 CDQ分治

    陌上花开 CDQ分治 传送门:https://www.luogu.org/problemnew/show/P3810 题意: \[ 有n 个元素,第 i 个元素有 a_i. b_i. c_i 三个属性 ...

  2. 【BZOJ-3262】陌上花开 CDQ分治(3维偏序)

    3262: 陌上花开 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 1439  Solved: 648[Submit][Status][Discuss ...

  3. bzoj3262陌上花开 cdq分治

    3262: 陌上花开 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 2794  Solved: 1250[Submit][Status][Discus ...

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

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

  5. 【CJOJ2433】陌上花开 CDQ分治

    [CJOJ2433]陌上花开 CDQ呲嘚秋分治 WA果然呲嘚秋分治跑得比树套树还快!!!(md理论复杂度不是一样的吗) 但树套树不知道比呲嘚秋高到哪里去辣装X用 Orz hzwer 第一维sort,第 ...

  6. 【BZOJ3262】陌上花开 cdq分治

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

  7. bzoj3262: 陌上花开(cdq分治+树状数组)

    3262: 陌上花开 题目:传送门 题解: %%%cdq分治 很强大的一个暴力...感觉比分块高级多了 这道题目就是一个十分经典的三维偏序的例题: 一维直接暴力排序x 二维用csq维护y 三维用树状数 ...

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

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

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

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

随机推荐

  1. springboot 发送邮件+模板+附件

    package com.example.demo; import org.junit.Test;import org.junit.runner.RunWith;import org.springfra ...

  2. 移动端自动化测试-WTF Appium?

    手机App分为两大类,原生App(Native App)和混合APP(Hybrid App) 原生App(Native App) 原生App实际就是我们所常见的传统App开发模式,云端数据存储+App ...

  3. 生活沉思录 via 哲理小故事(一)

    1.小托蒂的悲剧 意大利小男孩托蒂,有一只十分奇怪的眼睛,因为从生理上看,这是一只完全正常的眼睛,但却是失明的. 原来,托蒂刚出生时,这只眼睛轻度感染,曾用绷带缠了两个星期.这对常人来说几乎没有人任何 ...

  4. ExtJs 编译

    前台使用Extjs加载源码的话是非常庞大的,编译之后就只加载一个app.js文件.这种技能如果不知道的话怕别人骂我不是个女程序员.哈哈哈哈哈. 打开cmd,进入程序Extjs的文件夹,如我的程序Ext ...

  5. php5.6安装Zend Opcache扩展

    假设php5.6安装路径为/data2/php[root@nextcloud src]# pwd/usr/local/src[root@nextcloud src]# wget http://pecl ...

  6. zabbix监控-基本原理介绍

    一.Linux下开源监控系统简单介绍1)cacti:存储数据能力强,报警性能差2)nagios:报警性能差,存储数据仅有简单的一段可以判断是否在合理范围内的数据长度,储存在内存中.比如,连续采样数据存 ...

  7. hive基础操作—(1)

    执行./hive命令后,进入CLI(shell)模式: 1.创建数据库,语句: create database school; 2.展示所有的数据库,语句: show databases; 3.选择使 ...

  8. PairProject——结对编程

    成员:12061162  王骜 12061225  钟毅恒 一.合作过程中的照片 . 二.结对编程的优缺点 优点: 1)在编程过程中,任何一段代码都不断地复审,同时避免了将写代码的责任抛给一个人的问题 ...

  9. 网络:OSPF理解

    OSPF(开放最短路径优先)协议使用Dijkstra算法,常见的版本有:OSPFv2.OSPFv3等.以下主要介绍OSPFv2,OSPFv3是面向IPv6的且不兼容IPv4. 1.工作过程: 1)每台 ...

  10. Leetcode——258.各位相加【水题】

    给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数. 示例: 输入: 38 输出: 2 解释: 各位相加的过程为:3 + 8 = 11, 1 + 1 = 2. 由于 2 是一位数,所 ...