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. 产品概述 PIE-SDK是航天宏图自主研发的PIE二次开发组件包,集成了专业的遥感影像处理.辅助解译.信息提取.专题图表生成.二三维可视化等功能.底层采用微内核式架构,由跨平台的标准C++编写, ...
- PIE SDK K-Means分类
1.算法功能简介 K-Means 算法的基本思想是:以空间中 k 个点为中心进行聚类,对最靠近他们的对象归类.通过迭代的方法,逐次更新各聚类中心的值,直至得到最好的聚类结果. 算法首先随机从数据集中选 ...
- Win10小娜关闭或删除进程
先来说下我为什么想尽方法关闭win10小娜:我觉得功能并不适用于我,即便不启用Cortana小娜,在Win10进程中也会看到Cortana小娜启动着,耗费了内存.CPU,而且主要的我的磁盘利用率等都居 ...
- css 浮动元素居中
方法一 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...
- (转)linux命令详解之useradd命令使用方法
linux命令详解之useradd命令使用方法 原文:http://blog.csdn.net/u011537073/article/details/51987121 Linux 系统是一个多用户多任 ...
- Java开发环境搭建——IntelliJ Idea开发环境
IntelliJ Idea版本选择由于公司使用JDK7,所以我选择安装Version 2016.1.4(手动安装试验出来的,最新版的2016.1.4启动时提示需要安装JDK8)下载 前面说明有误,其实 ...
- Spring Security怎样不让默认的ProviderManager清除密码等信息
<authentication-manager erase-credentials="false"> ... </authentication-manager&g ...
- poj 1028 Web Navigation
Web Navigation Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 31088 Accepted: 13933 ...
- keepalive学习之软件设计
软件架构如下图所示: Keepalived 完全使用标准的ANSI/ISO C写出. 该软件主要围绕一个中央I/O复用分发器而设计,这个I/O复用分发器提供网络实时功能. 主要设计目标着重于从所有的模 ...
- js字符操作
js字符串方法预览: fromCharCode(num1, num2,,,), charAt(), charCodeAt(), length, split(''), slice(start, end? ...