洛谷P3810 陌上花开 (cdq)
最近才学了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)的更多相关文章
- 洛谷P3810 陌上花开 CDQ分治(三维偏序)
好,这是一道三维偏序的模板题 当然没那么简单..... 首先谴责洛谷一下:可怜的陌上花开的题面被无情的消灭了: 这么好听的名字#(滑稽) 那么我们看了题面后就发现:这就是一个三维偏序.只不过ans不加 ...
- 洛谷P3810 陌上花开(CDQ分治)
洛谷P3810 陌上花开 传送门 题解: CDQ分治模板题. 一维排序,二维归并,三维树状数组. 核心思想是分治,即计算左边区间对右边区间的影响. 代码如下: #include <bits/st ...
- BZOJ3262/洛谷P3810 陌上花开 分治 三维偏序 树状数组
原文链接http://www.cnblogs.com/zhouzhendong/p/8672131.html 题目传送门 - BZOJ3262 题目传送门 - 洛谷P3810 题意 有$n$个元素,第 ...
- P3810 陌上花开 CDQ分治
陌上花开 CDQ分治 传送门:https://www.luogu.org/problemnew/show/P3810 题意: \[ 有n 个元素,第 i 个元素有 a_i. b_i. c_i 三个属性 ...
- 洛谷 P3810 【模板】三维偏序(陌上花开) (cdq分治模板)
在solve(L,R)中,需要先分治solve两个子区间,再计算左边区间修改对右边区间询问的贡献. 注意,计算额外的贡献时,两子区间各自内部的顺序变得不再重要(不管怎么样左边区间的都发生在右边之前), ...
- [bzoj] 3263 陌上花开 洛谷 P3810 三维偏序|| CDQ分治 && CDQ分治讲解
原题 定义一个点比另一个点大为当且仅当这个点的三个值分别大于等于另一个点的三个值.每比一个点大就为加一等级,求每个等级的点的数量. 显然的三维偏序问题,CDQ的板子题. CDQ分治: CDQ分治是一种 ...
- 【洛谷P3810】陌上花开
题目大意:给定一个三维空间点的坐标,求对于任意一个点三维均小于等于这个点的点个数. 题解:学会了简单的 cdq 分治. 首先,先将第一维从小到大排序,再用类似归并排序的操作对第二维进行排序,在第二维合 ...
- [洛谷P3810]【模板】三维偏序(陌上花开)
题目大意:有$n$个元素,第$i$个元素有三个属性$a_i,b_i,c_i$,设$f(i)=\sum\limits_{i\not = j}[a_j\leqslant a_i,b_j\leqslant ...
- 洛谷P4390 Mokia CDQ分治
喜闻乐见的CDQ分治被我搞的又WA又T..... 大致思路是这样的:把询问用二维前缀和的思想拆成4个子询问.然后施CDQ大法即可. 我却灵光一闪:树状数组是可以求区间和的,那么我们只拆成两个子询问不就 ...
随机推荐
- DQL条件查询模糊查询和约束概述
模糊查询 -- 查询姓马的有哪些? like SELECT * FROM student where name LIKE '马%'; -- 查询姓名第二个字是化的人 SELECT * FROM stu ...
- CF Global Round 21 题解 (CDEG)
C 把 \(a,b\) 全拆开然后比较即可(因为分裂和合并是互逆的) 注意开 long long . using namespace std; typedef long long ll; typede ...
- Odoo14 给模块/应用加小图标
# apps中的图标是固定路劲: static/description/icon.png # 主页图标是通过你的主menuitem的web_icon来设置的: <menuitem id=&quo ...
- 3.26省选模拟+NOI-ONLINE
今日趣闻: 这三个人都是同机房的,卡最优解(大常数选手不参与)....以至于最优解第一页都是我们机房的(有图为证,共三人) $NOI\ online$ $T1$ 首先模拟一遍记录这个点当前单调栈前面位 ...
- Mybatis简单入门--插入数据
1. 开发环境 IDE:IDEA 构建工具:maven4.0.0 MySQL版本:8.0.11. 记得创建好数据库 Mybatis版本:3.5.7 MySQL不同版本的注意事项 驱动类driver-c ...
- 未关中断情况下的hardlock
最近遇到一例crash,3.10内核,hardlock,查看对应的堆栈,中断是使能的. 查看对应的hrtimer_interrupts和hrtimer_interrupt_save的值,发现确实相等. ...
- JS判断两个数组的元素是否完全相等
1.使用ES6 新增的扩展运算符和Set新数据类型判断两个数组是否包含有相同的元素 var arr1 = ['green' , 'yellow' ,'blue' ,'red']; var arr2 = ...
- 第五十篇: webpack中的loader(一) --css-loader
好家伙, 1.webpack配置中devServer节点的常用配置项 devServer:{ //首次打包完成后,自动打开浏览器 open:ture, //在http协议中,如果端口号是80,则可以被 ...
- Linux 破解mysql密码(详细步骤)
当mysql密码忘记时 [root@master ~]# mysql -uroot -p1 mysql: [Warning] Using a password on the command line ...
- 第十章 Kubernetes的CNI网络插件--flannel
1.简介 1.1前言 Kubernetes设计了网络模型,但却将它的实现讲给了网络插件,CNI网络插件最重要的功能就是实现Pod资源能够跨主机通信 常见的CNI网络插件如下: Flannel: Cac ...