最近才学了cdq,所以用cdq写的代码(这道题也是cdq的模板题)

这道题是个三维偏序问题,先对第一维排序,然后去掉重复的,然后cdq分治即可。

为什么要去掉重复的呢?因为相同的元素互相之间都能贡献,而cdq过程中只能左边贡献右边的,所以要去重。

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=200005;
4 struct node{
5 int a,b,c,cnt,ans;
6 }s1[N],s2[N];
7 int n,k,mx,m,top,su[N];
8 int c[N];//树状数组
9
10 bool cmp1(node x,node y){//按a排序
11 if(x.a==y.a){
12 if(x.b==y.b) return x.c<y.c;
13 else return x.b<y.b;
14 }
15 else return x.a<y.a;
16 }
17
18 bool cmp2(node x,node y){//cdq分治过程中对b排序
19 if(x.b==y.b) return x.c<y.c;
20 else return x.b<y.b;
21 }
22
23 int lowbit(int x){
24 return x&(-x);
25 }
26
27 void add(int x,int k){
28 while(x<=mx){
29 c[x]+=k;
30 x+=lowbit(x);
31 }
32 }
33
34 int query(int x){
35 int sum=0;
36 while(x){
37 sum+=c[x];
38 x-=lowbit(x);
39 }
40 return sum;
41 }
42
43 void cdq(int l,int r){//cdq
44 if(l==r) return ;
45 int mid=(l+r)>>1;
46 cdq(l,mid);cdq(mid+1,r);
47 sort(s2+l,s2+1+mid,cmp2);
48 sort(s2+mid+1,s2+r+1,cmp2);
49 int i,j=l;
50 for(int i=mid+1;i<=r;i++){//双指针计算结果
51 while(s2[i].b>=s2[j].b&&j<=mid){
52 add(s2[j].c,s2[j].cnt);
53 j++;
54 }
55 s2[i].ans+=query(s2[i].c);//计算ans
56 }
57 for(int i=l;i<j;i++){//清空数组
58 add(s2[i].c,-s2[i].cnt);
59 }
60 }
61
62 int main()
63 {
64 scanf("%d%d",&n,&k);
65 mx=k;
66 for(int i=1;i<=n;i++){
67 int a,b,c;
68 scanf("%d%d%d",&a,&b,&c);
69 s1[i].a=a;s1[i].b=b;s1[i].c=c;
70 }
71 sort(s1+1,s1+1+n,cmp1);
72 for(int i=1;i<=n;i++){//去掉重复的
73 top++;
74 if(s1[i].a!=s1[i+1].a||s1[i].b!=s1[i+1].b||s1[i].c!=s1[i+1].c){
75 m++;
76 s2[m].a=s1[i].a;s2[m].b=s1[i].b;s2[m].c=s1[i].c;
77 s2[m].cnt=top;
78 top=0;
79 }
80 }
81 cdq(1,m);
82 for(int i=1;i<=m;i++) su[s2[i].ans+s2[i].cnt-1]+=s2[i].cnt;
83 for(int i=0;i<n;i++)
84 cout<<su[i]<<endl;
85 return 0;
86 }

洛谷P3810 陌上花开 (cdq)的更多相关文章

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

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

  2. 洛谷P3810 陌上花开(CDQ分治)

    洛谷P3810 陌上花开 传送门 题解: CDQ分治模板题. 一维排序,二维归并,三维树状数组. 核心思想是分治,即计算左边区间对右边区间的影响. 代码如下: #include <bits/st ...

  3. BZOJ3262/洛谷P3810 陌上花开 分治 三维偏序 树状数组

    原文链接http://www.cnblogs.com/zhouzhendong/p/8672131.html 题目传送门 - BZOJ3262 题目传送门 - 洛谷P3810 题意 有$n$个元素,第 ...

  4. P3810 陌上花开 CDQ分治

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

  5. 洛谷 P3810 【模板】三维偏序(陌上花开) (cdq分治模板)

    在solve(L,R)中,需要先分治solve两个子区间,再计算左边区间修改对右边区间询问的贡献. 注意,计算额外的贡献时,两子区间各自内部的顺序变得不再重要(不管怎么样左边区间的都发生在右边之前), ...

  6. [bzoj] 3263 陌上花开 洛谷 P3810 三维偏序|| CDQ分治 && CDQ分治讲解

    原题 定义一个点比另一个点大为当且仅当这个点的三个值分别大于等于另一个点的三个值.每比一个点大就为加一等级,求每个等级的点的数量. 显然的三维偏序问题,CDQ的板子题. CDQ分治: CDQ分治是一种 ...

  7. 【洛谷P3810】陌上花开

    题目大意:给定一个三维空间点的坐标,求对于任意一个点三维均小于等于这个点的点个数. 题解:学会了简单的 cdq 分治. 首先,先将第一维从小到大排序,再用类似归并排序的操作对第二维进行排序,在第二维合 ...

  8. [洛谷P3810]【模板】三维偏序(陌上花开)

    题目大意:有$n$个元素,第$i$个元素有三个属性$a_i,b_i,c_i$,设$f(i)=\sum\limits_{i\not = j}[a_j\leqslant a_i,b_j\leqslant ...

  9. 洛谷P4390 Mokia CDQ分治

    喜闻乐见的CDQ分治被我搞的又WA又T..... 大致思路是这样的:把询问用二维前缀和的思想拆成4个子询问.然后施CDQ大法即可. 我却灵光一闪:树状数组是可以求区间和的,那么我们只拆成两个子询问不就 ...

随机推荐

  1. CentOS删除桌面环境

    公司有几台虚拟机安装的是CentOS7的桌面环境,平时也是用终端访问,于是在服务器卡住需要重启时,顺便就把桌面环境给卸载了:测试了好多方法均不成功,最终找到了可行的方式,以此记录: [root@yun ...

  2. vue 数据更新了但视图没改变?试试 $set

    场景 编辑表格中某行数据时,需要把它赋值给对话框表单 this.form,如果直接用 = 赋值,会导致:表单的输入框内容无法二次编辑. 使用 Vue-dev-tool 的 Components 功能测 ...

  3. 6.8 NOI 模拟

    \(T1\ edge\) 考虑\(O(q\times n\times \log n)\)的暴力 暴力二分,直接树上差分 #define Eternal_Battle ZXK #include<b ...

  4. CF242E XOR on Segment

    CF242E XOR on Segment codeforces 洛谷 关于异或,无法运用懒标记实现区间异或: 可以像trie树一样拆位,将每个值拆成二进制数,对此建相应个数的线段树. 0 1与 0异 ...

  5. 在生鲜零售业,DolphinScheduler 还能这么玩!

    点击上方 蓝字关注我们 ✎ 编 者 按 2021 年,Apache DolphinScheduler 社区又迎来了新的蓬勃发展,社区活跃度持续提高.目前,项目 GitHub Star 已达 6.7k, ...

  6. 【Meetup回顾】Apache DolphinScheduler在联通的实践和二次开发经验分享

    在由 openLooKeng 社区主办,Apahce DolphinScheduler社区.Apache Pulsar 社区.示说网协办的联合 Meetup 上,来自联通数字科技的王兴杰老师分享了Do ...

  7. 向日葵远程RCE漏洞分析及漏洞利用脚本编写

    0x00 漏洞概述 向日葵是一款免费的,集远程控制电脑.手机.远程桌面连接.远程开机.远程管理.支持内网穿透等功能的一体化远程控制管理软件.如果想要手机远控电脑,或者电脑远控手机可以利用向日葵:如果是 ...

  8. Find-Vulnerability 自动化探测扫描工具简介

    Fvuln 简介 F-vuln(全称:Find-Vulnerability)是一款自动化探测扫描工具,主要适用于日常安全服务.渗透测试人员和RedTeam红队人员使用 它集合的功能包括: 存活IP探测 ...

  9. C语言小游戏: 推箱子 支线(一)--1

    好家伙,考完试了 回顾一下2021 回顾一下某次的作业 妙啊 所以, 做一个推箱子小游戏 1.先去4399找一下关卡灵感 就它了 2.在百度上搜几篇推箱子, 参考其中的"■ ☆"图 ...

  10. HBase集群部署与基础命令

    HBase 集群部署 安装 hbase 之前需要先搭建好 hadoop 集群和 zookeeper 集群.hadoop 集群搭建可以参考:https://www.cnblogs.com/javammc ...