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. ...
随机推荐
- restful设计参考
https://www.cnblogs.com/pyspark/p/8599210.html 以下查阅多处文档,思考总结: 所谓restful规范代表一种理想状态,首先对此种规范表示赞同,但应不忘实事 ...
- SQLServer2005:在执行时出现错误。错误消息为: 目录名无效
删除数据时忘了想delete删除的话会记录日志,更何况是我删除百万条数据,结果还没删完服务器内存就占慢了,一切数据都进不来了,估计这种情况导致我的数据库有问题了,右键打开表提示:目录名无效,执行SQL ...
- 【算法】状态压缩DP
状态压缩DP是什么? 答:利用位运算(位运算比加减乘除都快!)来记录状态,并实现动态规划. 适用于什么问题? 答:数据规模较小:不能使用简单的算法解决. 例题: 题目描述 糖果店的老板一共有M 种口味 ...
- 《TCP/IP入门经典》摘录--Part 2
TCP/IP协议系统 1.网络访问层 网卡(network adapter),即网络接口板,又称网络适配器或NIC (网络接口控制器),是一块被设计用来允许计算机在计算机网络上进行通讯的计算机硬件,由 ...
- laravel 增强代码提示功能插件
1.在项目根目录命令输入(使用composer安装) composer require barryvdh/laravel-ide-helper 2.在config/app.php中添加代码如下: 'p ...
- String类中的equals方法总结(转载)
转载:https://blog.csdn.net/qq_25827845/article/details/53868815 1.String源码中equals大致写法: public boolean ...
- beego orm 多对多插入和查询操作
// User 用户表 type User struct { ID int UserName string Password string Articles []*Article `orm:" ...
- koa2第一天 async详解
一.什么是async async其实是ES7的才有的关键字,放在这里说,其实是和我们前面所说的Promise,Generator有很大关联的.async的意思是"异步",顾名 ...
- centos useradd 命令详解
useradd 命令 Usage: useradd [options] LOGIN useradd -D useradd -D [options] Options: -b, --base-dir BA ...
- mutiprocessing 同步类型,如锁,条件和队列官方案例:
官方文档:https://docs.python.org/2/library/multiprocessing.html#module-multiprocessing 1. 同步类型,如锁,条件和队列官 ...