最近才学了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. [Linux] 如何在 Linux 电脑上制作专业的视频教程

    目录 前言 1.软件工具准备 a. 录音软件 b. 录屏软件 c. 摄像头软件 d. 安卓屏幕操作软件 e. 视频剪辑软件 2.视频教程制作 3.效果 参考链接 前言 博主使用 Arch Linux ...

  2. 题解【CodeForces 910A The Way to Home】

    题目大意 一只青蛙现在在一个数轴上,它现在要从点 \(1\) 跳到点 \(n\) ,它每次可以向右跳不超过 \(d\) 个单位.比如,它可以从点 \(x\) 跳到点 \(x+a\)(\(1\le a\ ...

  3. mysql查询版本

    系统环境下 :mysql -V; mysql内:select version();

  4. SQLServer查询进程与死锁语句

    查询当前进程信息: SELECTSPID = er.session_id,Status = ses.status,[Login] = ses.login_name,Host = ses.host_na ...

  5. Mybatis的使用(4)

    1:解决实体类成员变量和数据库表中字段名称不一致的问题: 方法1:在写sql语句时,给表中的列名起别名,名字和实体类名称一样 方法2:使用resultMap来解决: 例如:实体类中成员变量为id,na ...

  6. v-model原理问题

    v-model的原理 很多同学在理解Vue的时候都把Vue的数据响应原理理解为双向绑定,但实际上这是不准确的,我们之前提到的数据响应,都是通过数据的改变去驱动DOM重新的变化,而双向绑定已有数据驱动D ...

  7. Prometheus+Grafana+钉钉部署一个单机的MySQL监控告警系统

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. GreatSQL是MySQL的国产分支版本,使用上与MySQL一致. 目录 一.Prometheus 二.exporter ...

  8. 一文带你掌握Spring Web异常处理方式

    一.前言 大家好,我是 去哪里吃鱼 ,也叫小张. 最近从单位离职了,离开了五年多来朝朝夕夕皆灯火辉煌的某网,激情也好悲凉也罢,觥筹场上屡屡物是人非,调转过事业部以为能换种情绪,岂料和下了周五的班的前同 ...

  9. day19--Java集合02

    Java集合02 6.ArrayList ArrayList的注意事项: Permits all element , including null ,ArrayList 可以加入null ,并且可以加 ...

  10. 企业运维实践-Nginx使用geoip2模块并利用MaxMind的GeoIP2数据库实现处理不同国家或城市的访问最佳实践指南

    关注「WeiyiGeek」公众号 设为「特别关注」每天带你玩转网络安全运维.应用开发.物联网IOT学习! 希望各位看友[关注.点赞.评论.收藏.投币],助力每一个梦想. 本章目录 目录 0x00 前言 ...