BZOJ 3262 陌上花开 ——CDQ分治
【题目分析】
多维问题,我们可以按照其中一维排序,然后把这一维抽象的改为时间。
然后剩下两维,就像简单题那样,排序一维,树状数组一维,按照时间分治即可。
挺有套路的一种算法。
时间的抽象很巧妙。
同种的花需要处理,合并在一起计算即可。
【代码】
#include <cstdio> #include <cstring> #include <iostream> #include <vector> #include <algorithm> using namespace std; #define ll long long #define maxn 300005 struct flo{int a,b,c,id;}q[maxn],eq[maxn],nq[maxn]; int cnt,k,top=0,ans[maxn],T,c[maxn]; vector <int> v[maxn]; bool cmp(flo x,flo y) { if (x.a==y.a&&x.b==y.b) return x.c<y.c; if (x.a==y.a) return x.b<y.b; return x.a<y.a; } bool cmp2(flo x,flo y) { if (x.b==y.b&&x.c==y.c) return x.a<y.a; if (x.b==y.b) return x.c<y.c; return x.b<y.b; } struct Bit_Tree{ int v[maxn]; void init(){memset(v,0,sizeof v);} void add(int x,int f) {for (;x<=k;x+=x&(-x)) v[x]+=f;} int sum(int x) { int ret=0; for (;x;x-=x&(-x)) ret+=v[x]; return ret; } }t; void solve(int l,int r) { if (l==r) return ; int mid=(l+r)/2; for (int i=l;i<=r;++i) { if (eq[i].a<=mid) t.add(eq[i].c,v[eq[i].id].size()); if (eq[i].a>mid) { int tmp=t.sum(eq[i].c); for (int j=0;j<v[eq[i].id].size();++j) ans[v[eq[i].id][j]]+=tmp; } } int p1=l,p2=mid+1; for (int i=l;i<=r;++i) if (eq[i].a<=mid) t.add(eq[i].c,-v[eq[i].id].size()); for (int i=l;i<=r;++i) if (eq[i].a<=mid) nq[p1++]=eq[i]; else nq[p2++]=eq[i]; for (int i=l;i<=r;++i) eq[i]=nq[i]; solve(l,mid); solve(mid+1,r); } int main() { scanf("%d%d",&cnt,&k); for (int i=1;i<=cnt;++i) scanf("%d%d%d",&q[i].a,&q[i].b,&q[i].c),q[i].id=i; sort(q+1,q+cnt+1,cmp); for (int i=1;i<=cnt;++i) { if (!top) eq[++top]=q[i],v[top].push_back(q[i].id); else if (eq[top].a!=q[i].a||eq[top].b!=q[i].b||eq[top].c!=q[i].c) eq[++top]=q[i],v[top].push_back(q[i].id); else v[top].push_back(q[i].id); eq[top].id=top; } for (int i=1;i<=top;++i) eq[i].a=i; sort(eq+1,eq+top+1,cmp2); solve(1,top); for (int i=1;i<=top;++i) for (int j=0;j<v[eq[i].id].size();++j) ans[v[eq[i].id][j]]+=v[eq[i].id].size()-1; for (int i=1;i<=cnt;++i) c[ans[i]]++; for (int i=0;i<cnt;++i) printf("%d\n",c[i]); }
BZOJ 3262 陌上花开 ——CDQ分治的更多相关文章
- bzoj 3262 陌上花开 - CDQ分治 - 树状数组
Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...
- BZOJ 3262: 陌上花开 [CDQ分治 三维偏序]
Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...
- BZOJ 3262 陌上花开 CDQ分治
= =原来复杂度还是nlog^2(n) Orz 被喷了 #include<cstdio> #include<cstdlib> #include<algorithm> ...
- BZOJ 3262: 陌上花开 (cdq分治,三维偏序)
#include <iostream> #include <stdio.h> #include <algorithm> using namespace std; c ...
- BZOJ 3262: 陌上花开 CDQ
这个题大部分人用了离散然后水之,然而.....作为一只蒟蒻我并没有想到离散,而是直接拿两个区间一个对应n,一个对应k来搞,当然这两个区间是对应的,我把第一维排序,第二维CDQ,第三维树状数组,然而由于 ...
- [BZOJ 3456]城市规划(cdq分治+FFT)
[BZOJ 3456]城市规划(cdq分治+FFT) 题面 求有标号n个点无向连通图数目. 分析 设\(f(i)\)表示\(i\)个点组成的无向连通图数量,\(g(i)\)表示\(i\)个点的图的数量 ...
- [BZOJ 2989]数列(CDQ 分治+曼哈顿距离与切比雪夫距离的转化)
[BZOJ 2989]数列(CDQ 分治) 题面 给定一个长度为n的正整数数列a[i]. 定义2个位置的graze值为两者位置差与数值差的和,即graze(x,y)=|x-y|+|a[x]-a[y]| ...
- P3810 陌上花开 CDQ分治
陌上花开 CDQ分治 传送门:https://www.luogu.org/problemnew/show/P3810 题意: \[ 有n 个元素,第 i 个元素有 a_i. b_i. c_i 三个属性 ...
- Luogu 3810 & BZOJ 3262 陌上花开/三维偏序 | CDQ分治
Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...
随机推荐
- C++ 共享内存 函数封装
#pragma once #include <string> #include <wtypes.h> #include <map> using namespace ...
- swift与OC之间不得不知道的21点
swift与OC之间不得不知道的21点 自6月的WWDC大会上由苹果的大神Chris Lattner向我们首次展示swift至今已经大半年时间了,虽然绝大部分软件公司代码里还都见不到一丁点swif ...
- git error: unable to rewind rpc post data - try increasing http.postBuffer
error: unable to rewind rpc post data - try increasing http.postBuffererror: RPC failed; curl 56 Rec ...
- angularJS实践过程中出现的问题总结
同名服务 在一次项目里,之前是同事写的.我有一次在异步获取服务器上的数据时,习惯把api地址写在一个服务Store里,但是程序总是返回Store.api.get()里的get is undefined ...
- js词法分析
JavaScript的高级知识---词法分析 词法分析 词法分析方法: js运行前有一个类似编译的过程即词法分析,词法分析主要有三个步骤: 分析参数 再分析变量的声明 分析函数说明 函数在运行的瞬间, ...
- 重视blog备份——兼记我与CSDN的爱恨情仇
痛定思痛,终于决定--逐渐备份.迁移CSDN博客到"博客园". 缘起 前几年比较喜欢逛csdn的bbs,虽然之前在cnblogs也注册了账号,但一直用CSDN博客比较多.本来一直用 ...
- Sublime 3 如何设置xftp 排除文件夹“bower_components”,“node_modules”
“bower_components”,“node_modules”这个文件夹,作为模块得引用文件,不需要下载本地进行编码,这里得文件非常多,若是不把这个两个文件夹排除掉掉话,通过xftp下载所有文件的 ...
- C/C++: C++变量和基本类型
1. 如何选择类型的准则 当明确知晓数值不可能为负的时候,应该选择无符号类型. 使用int执行整数运算的时候,在实际应用中,short常常显得太小而long一般和int有一样的尺寸,如果数值超过了in ...
- pureftp 服务
没啥图,不喜勿喷---_- ftp(file transfer protocol)--文件传输协议 (a)官网:www.pureftpd.org (b)原理 让用户连接上一个远程计算机(运行FTP ...
- 如何下架app
因赶数日工期成,偷得浮生半日闲.遂登录iTunes Connect,发现之前做过的小程序,想将其下架,故而有此篇随想.(温馨提示:项目被下架后再次上架该版本,不需要再次经过审核)下面是详情步骤: 1. ...