BZOJ3262:陌上花开(CDQ分治)
Description
Input
Output
包含N行,分别表示评级为0...N-1的每级花的数量。
Sample Input
3 3 3
2 3 3
2 3 1
3 1 1
3 1 2
1 3 1
1 1 2
1 2 2
1 3 2
1 2 1
Sample Output
1
3
0
1
0
1
0
0
1
Solution
顺便借这个题学了一下一直没碰过的树状数组……
首先对于三维偏序$(a,b,c)$,我们可以以a为关键字进行sort,
这样数组中的a就是有序的,每次分治当前区间我们只考虑左半边对右半边的贡献,这样就可以消除a的影响QAQ
再观察一下现在要解决的问题,统计$b_{j}<=b_{i}$且$c_{j}<=c[i]$
如果我们把b当做数组下标,c当数组下标里的值的话,可以想到什么?逆序对!不过这里是个顺序对就是了
所以就是第一维使其sort有序,第二维分治的时候归并排序使其有序,第三维用树状数组进行统计
注意要去重,否则如果A=B,那么(A,B)(B,A)本来都是可以的,但分治的时候不去重我们只能考虑进去一种
Code
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N (200000+1000)
using namespace std; int n,k,emm,top,c[N],ans[N]; int lowbit(int x){return x&-x;}
int add(int x,int delta){for (; x<=k; x+=lowbit(x)) c[x]+=delta;}
int sum(int x){int sum=; for (; x; x-=lowbit(x)) sum+=c[x]; return sum;} struct Node
{
int a,b,c,size,ans;
bool operator < (const Node &A) const
{
if (a==A.a && b==A.b) return c<A.c;
if (a==A.a) return b<A.b;
return a<A.a;
}
}a[N],t[N]; void CDQ(int l,int r)
{
if (l==r) return;
int mid=(l+r)>>;
CDQ(l,mid); CDQ(mid+,r);
int i=l,j=mid+,p=l;
while (i<=mid || j<=r)
{
if (j>r || i<=mid && a[i].b<=a[j].b) add(a[i].c,a[i].size),t[p++]=a[i++];
else a[j].ans+=sum(a[j].c),t[p++]=a[j++];
}
for (int i=l; i<=mid; ++i) add(a[i].c,-a[i].size);
for (int i=l; i<=r; ++i) a[i]=t[i];
} int main()
{
scanf("%d%d",&n,&k); emm=n;
for (int i=; i<=n; ++i)
scanf("%d%d%d",&a[i].a,&a[i].b,&a[i].c),a[i].size=;
sort(a+,a+n+);
top=;
for (int i=; i<=n; ++i)
{
if (a[i].a==a[top].a && a[i].b==a[top].b && a[i].c==a[top].c)
a[top].size++;
else a[++top]=a[i];
}
n=top;
CDQ(,n);
for (int i=; i<=n; ++i) ans[a[i].ans+a[i].size-]+=a[i].size;
for (int i=; i<emm; ++i) printf("%d\n",ans[i]);
}
BZOJ3262:陌上花开(CDQ分治)的更多相关文章
- bzoj3262陌上花开 cdq分治
3262: 陌上花开 Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 2794 Solved: 1250[Submit][Status][Discus ...
- bzoj3262陌上花开 cdq分治入门题
Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...
- bzoj3262: 陌上花开(cdq分治+树状数组)
3262: 陌上花开 题目:传送门 题解: %%%cdq分治 很强大的一个暴力...感觉比分块高级多了 这道题目就是一个十分经典的三维偏序的例题: 一维直接暴力排序x 二维用csq维护y 三维用树状数 ...
- bzoj3262 陌上花开 cdq分治(入门)
题目传送门 思路:cdq分治处理偏序关系的模板题,主要就是学cdq分治吧,还在入门中. 代码其实也很好理解,记得树状数组操作的上限是 z的最大值,不是n的最大值,这个细节wa了好久. #include ...
- bzoj3262 陌上花开——CDQ分治
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3262 第一道CDQ分治题! 看博客:https://www.cnblogs.com/Narh ...
- 【学术篇】bzoj3262 陌上花开. cdq分治入门
花儿们已经很累了-- 无论是花形.颜色.还是气味, 都不是为了给人们摆出来欣赏的, 更不是为了当做出题的素材的, 她们并不想自己这些属性被没有生命的数字量化, 并不想和其它的花攀比, 并无意分出个三六 ...
- [Bzoj3262]陌上花开(CDQ分治&&树状数组||树套树)
题目链接 题目就是赤裸裸的三维偏序,所以用CDQ+树状数组可以比较轻松的解决,但是还是树套树好想QAQ CDQ+树状数组 #include<bits/stdc++.h> using nam ...
- P3810 陌上花开 CDQ分治
陌上花开 CDQ分治 传送门:https://www.luogu.org/problemnew/show/P3810 题意: \[ 有n 个元素,第 i 个元素有 a_i. b_i. c_i 三个属性 ...
- 【BZOJ3262】陌上花开 cdq分治
[BZOJ3262]陌上花开 Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义 ...
随机推荐
- PIE SDK专题制图下地图的的操作
1. 功能简介 制图模式和地图模式下用的地图是同一份地图,那么在制图模式下如果需要对地图进行操作(例如地图的拉框放大,缩小),那么该如何操作呢,地图范围视图变化在制图模式下该如何监听呢,下面主要 ...
- mysql 查询 TOP N 问题
Q:有一个学生成绩表,表名 stu(学生表),字段有:id(主键),name(学生姓名),subject(学科),score(分数) 1.查询该表中,所有科目都及格的学生 ; 说明:都及格的话,就是最 ...
- Ignite cahce 存储object类型数据和object类型数据序列化后string存储区别
Ignite cache在存储时 object类型的数据和 序列化该object成string类型 两者存储时间差不多. 但是这两者在读取出来的时候,string类型比object类型快很多. 以下为 ...
- Zabbix的安装(源码安装)
zabbix3.0完全安装 安装zabbix首先需要安装ltmp(lnmp),这里的t是指tengine(taobao的nginx版本),安装教程见 http://www.ltmp.cc 安装的时候P ...
- GitHub(hexo)博客页面访问量错误以及中文乱码解决
如果访问量不显示(乱码形状),是因为不蒜子域名更新,所以你的域名也需要更新 <script async src="//busuanzi.ibruce.info/busuanzi/2.3 ...
- sudo apt-get install openssh-server时提示需要安装1:6.6p1-2ubuntu1的解决办法(图文详解)
最近,在执行 sudo apt-get install openssh-server 提示,如下. 解决办法 先要执行 sudo apt-get install openssh-client=1:6. ...
- 数据库~大叔通过脚本生成poco实体
今天在做开发时,需要把表映射成实体,又没有EF这种工具,就从网上下了一个工具,但使用时觉得太重了,所以就自己写了一个,基于mysql的. 功能:输入表名,得到这个表的poco实体 SELECT COL ...
- 安装 fedora 之后
下载zsh,并安装oh-my-zsh dnf install zsh -y 到github的oh-my-zsh上按照教程安装oh-my-zsh,配置主题为minimal,这个是个人比较喜欢的主题,因为 ...
- 创建Django项目时,settings的静态文件的配置
STATICFILES_DIRS = ( os.path.join(BASE_DIR,'static'), )
- 【Linux相识相知】任务计划和周期性任务
在我们的生活中,有的工作是例行的,例如每年一次加薪.每年给女朋友过一次生日.每天上班都要打卡等,有的工作是临时发生的,例如明天朋友要来访,你需要准备午餐等等. 像很多例行的工作,你一旦忙起来就很容易忘 ...