BZOJ 3262: 陌上花开 (cdq分治,三维偏序)
#include <iostream>
#include <stdio.h>
#include <algorithm>
using namespace std;
const int maxn=1e5+10;
const int maxk=2e5+10;
int n,k;
struct Triple {
int a,b,c,cnt,ans;
}a[maxn],A[maxn];
bool cmp(const Triple &a,const Triple &b) {
if (a.a!=b.a) {
return a.a<b.a;
}
else if (a.b!=b.b) {
return a.b<b.b;
}
return a.c<b.c;
}
struct BitIndexTree {
int a[maxk];
int lowbit(const int x) {
return x&(-x);
}
void Update(const int x,const int delta) {
for (int i=x;i<=k;i+=lowbit(i)) {
a[i]+=delta;
}
}
void Clean(const int x) {
for (int i=x;i<=k;i+=lowbit(i)) {
if (a[i]) {
a[i]=0;
}
else {
break;
}
}
}
int Query(const int x) {
int ans=0;
for (int i=x;i>0;i-=lowbit(i)) {
ans+=a[i];
}
return ans;
}
}bit;
void CDQ(Triple *l,Triple *r)
{
if (l==r) {
l->ans+=l->cnt-1;
return ;
}
Triple *mid=l+(r-l)/2;
CDQ(l,mid);
CDQ(mid+1,r);
static Triple tmp[maxn];
for (Triple *p=tmp,*p1=l,*p2=mid+1;p<=tmp+(r-l);p++) {
if ((p1<=mid&&p1->b<=p2->b)||p2>r) {
*p=*p1++;
bit.Update(p->c,p->cnt);
}
else {
*p=*p2++;
p->ans+=bit.Query(p->c);
}
}
for (Triple *p=tmp,*q=l;q<=r;p++,q++) {
bit.Clean(p->c);
*q=*p;
}
}
template <typename T>
inline void read(T &x)
{
int f=1;
x=0;
register char ch;
ch=getchar();
while (ch>'9'||ch<'0') {
if (ch=='-') {
f=-f;
}
ch=getchar();
}
while (ch>='0'&&ch<='9') {
x=x*10+ch-'0';
ch=getchar();
}
x*=f;
}
inline void write(int x)
{
if (x<0) {
putchar('-');
}
if (x>9) {
write(x/10);
}
putchar(x%10+'0');
}
int main()
{
scanf("%d%d",&n,&k);
for (int i=0;i<n;i++) {
read(a[i].a),read(a[i].b),read(a[i].c);
// scanf("%d%d%d",&a[i].a,&a[i].b,&a[i].c);
a[i].cnt=1;
}
sort(a,a+n,cmp);
int cnt=0;
for (int i=0;i<n;i++) {
if (i==0||!(a[i].a==a[i-1].a&&a[i].b==a[i-1].b&&a[i].c==a[i-1].c)) {
A[cnt++]=a[i];
}
else {
A[cnt-1].cnt+=1;
}
}
CDQ(A,A+cnt-1);
static int ans[maxn];
for (int i=0;i<cnt;i++) {
ans[A[i].ans]+=A[i].cnt;
}
for (int i=0;i<n;i++) {
write(ans[i]);
putchar('\n');
// printf("%d\n",ans[i]);
}
return 0;
}
BZOJ 3262: 陌上花开 (cdq分治,三维偏序)的更多相关文章
- BZOJ 3262: 陌上花开 [CDQ分治 三维偏序]
Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...
- bzoj 3262 陌上花开 - CDQ分治 - 树状数组
Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...
- 洛谷P3810 陌上花开 CDQ分治(三维偏序)
好,这是一道三维偏序的模板题 当然没那么简单..... 首先谴责洛谷一下:可怜的陌上花开的题面被无情的消灭了: 这么好听的名字#(滑稽) 那么我们看了题面后就发现:这就是一个三维偏序.只不过ans不加 ...
- BZOJ 3262 陌上花开 ——CDQ分治
[题目分析] 多维问题,我们可以按照其中一维排序,然后把这一维抽象的改为时间. 然后剩下两维,就像简单题那样,排序一维,树状数组一维,按照时间分治即可. 挺有套路的一种算法. 时间的抽象很巧妙. 同种 ...
- BZOJ 3262 陌上花开 CDQ分治
= =原来复杂度还是nlog^2(n) Orz 被喷了 #include<cstdio> #include<cstdlib> #include<algorithm> ...
- BZOJ - 1935 / 1176 cdq分治 三维偏序
题意:给定n*m的网格,且给出n个(x,y)表示该网格已被占有,q次询问(x1,y1)到(x2,y2)的网格中有多少个被占有,n,m范围1e7,q范围5e5 cdq按x轴排序,树状数组维护y轴 #in ...
- BZOJ 2244: [SDOI2011]拦截导弹 (CDQ分治 三维偏序 DP)
题意 略- 分析 就是求最长不上升子序列,坐标取一下反就是求最长不下降子序列,比较大小是二维(h,v)(h,v)(h,v)的比较.我们不看概率,先看第一问怎么求最长不降子序列.设f[i]f[i]f[i ...
- cdq分治·三维偏序问题
转载自FlashHu大佬的博客CDQ分治总结(CDQ,树状数组,归并排序),在讲述部分有部分删改,用了自己的代码 CDQ分治的思想 CDQ分治是基于时间的离线分治算法.这一类分治有一个重要的思想——用 ...
- 【算法】CDQ分治 -- 三维偏序 & 动态逆序对
初次接触CDQ分治,感觉真的挺厉害的.整体思路即分而治之,再用之前处理出来的答案统计之后的答案. 大概流程是(对于区间 l ~ r): 1.处理 l ~mid, mid + 1 ~ r 的答案: 2. ...
随机推荐
- 0005 修改Django工程名
写框架非常耗时间,把框架写好以后,经测试稳定的框架,需要保存下来,以后有工程需要,直接更改工程名即可. 01 右键点击工程名,点击Refactor/Rename 02 选择更改工程名 03 关闭PyC ...
- Codeforces Round #600 (Div. 2) A. Single Push
#include<iostream> #include<cstdio> #include<cstdlib> using namespace std; int T,n ...
- thinkphp3.2 中 Memcache 的配置和使用(memcahe的使用场景)
Thinkphp的默认缓存方式是以File方式,在/Runtime/Temp 下生成了好多缓存文件. TIPS: TP3.2支持的缓存方式有:数据缓存类型,支持:File|Db|Apc|Memcach ...
- .htaccess详解
http://www.cnblogs.com/adforce/archive/2012/11/23/2784664.html .htaccess是什么 .htaccess文件(或者"分布式配 ...
- EF简单的CodeFirst示例(自己创建数据库,不使用数据迁移)
1.新建一个控制台应用程序 2.右键引用--管理NuGet程序包,安装如下几项 3.打开App.config文件,加入如下代码: <connectionStrings> <ad ...
- Unity 坐标系转换
在Unity中我们通常会用到以下几个坐标系下的点: 世界坐标系:World Space 简单来讲,我们通过 transform.position | transform.rotation 获取得到的位 ...
- Java+Selenium+Testng自动化测试学习(四)— 报告
自动化测试报告,在测试用例完成之后系统自动生成HTML报告 使用testng中的报告模板生成报告, 1.在TestSuit.xml文件中配置报告监听 2.运行xml文件 3.自动生成一个test-ou ...
- TCP/IP协议-为什么说TCP是可靠连接
我们平常经常说UDP是不可靠连接,TCP是可靠连接,然而TCP为什么是可靠的呢 1. TCP和UDP的优缺点TCP 缺点: [1] 三次握手四次挥手,传输更多包,浪费一些带宽[2] 为了进行可靠通信, ...
- [git] git合并冲突 本地已有项目上传 各种问题
git... 讲道理 我现在能隐约感觉到他的强大控制能力了 但是依旧是不习惯.... 无论是什么操作 在我这里都会出问题,,,, 上传本地已有的项目到码云 首先需要现在码云创建一个仓库 然后用git工 ...
- 题解【loj6277】数列分块入门1
题目描述 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及区间加法,单点查值. 输入格式 第一行输入一个数字\(n\). 第二行输入\(n\)个数字,第\(i\)个数字为\(a_{i}\) ...