题目传送门

第一次接触CDQ分治,感谢YZ大佬的教导。

CDQ分治就是一种奇特的分治方法,它用左区间的区间信息来更新右区间。

设CDQ(L,R,l,r)表示递归到区间[L,R],区间的值为[l,r]。

mid=l+r/2。

将L~R区间按<=mid和>mid的两块重新分开。

继续递归区间分治。

CDQ分治用于解决一类偏序问题,题目中所求的为三维偏序。

即计算一类ai<bi,aj<bj,ak<bk的贡献。

普通的二维偏序大家都做过,经典题目逆序对。

三维怎么做呢?

第一维依然是SORT,第三位是树状数组。

第二维是CDQ。

第一维SORT后有序,故无需考虑第一维。

第二维CDQ分治时枚举L~R区间,当a[i].y>mid时,计算在权值树状数组上的贡献,否则插入树状数组。

注意:这道题需要对重复区间判重,否则贡献值不好算。

code:

/**************************************************************
    Problem: 3262
    User: yekehe
    Language: C++
    Result: Accepted
    Time:1116 ms
    Memory:10600 kb
****************************************************************/
 
#include <cstdio>
#include <algorithm>
using namespace std;
 
char tc()
{
    static char tr[],*A=tr,*B=tr;
    return A==B&&(B=(A=tr)+fread(tr,,,stdin),A==B)?EOF:*A++;
}
 
int read()
{
    char c;while(c=tc(),c<''||c>'');
    int x=c-'';while(c=tc(),c>=''&&c<='')x=x*+c-'';
    return x;
}
 
struct node{
    int x,y,z,o;
}a[],lx[],rx[],Ne[];
int N,K,cnt;
int at[],b[],tim,ans[],tot[];
inline int cmp(node x,node y){return x.x<y.x || x.x==y.x&&x.y<y.y || x.x==y.x&&x.y==y.y&&x.z<y.z;}
 
void add(int x,int y)
{
    for(int i=x;i<=K;i+=i&-i){
        if(b[i]!=tim)at[i]=,b[i]=tim;
        at[i]+=y;
    }
    return ;
}
 
int get(int x)
{
    int tot=;
    for(int i=x;i;i-=i&-i)
        if(!(b[i]^tim))tot+=at[i];
    return tot;
}
 
void cdq(int L,int R,int l,int r)
{
    tim++;
    int mid=l+r>>,lt=,rt=;
        for(int i=L;i<=R;i++){
            if(!(l^r)){
                ans[Ne[i].o]+=get(Ne[i].z);
                add(Ne[i].z,tot[Ne[i].o]);
            }
            else{
                if(Ne[i].y<=mid)add(Ne[i].z,tot[Ne[i].o]);
                else ans[Ne[i].o]+=get(Ne[i].z);
            }
        }//统计贡献
        for(int i=L;i<=R;i++){
            if(Ne[i].y<=mid)lx[++lt]=Ne[i];
            else rx[++rt]=Ne[i];
        }
        for(int i=;i<=lt;i++)Ne[L+i-]=lx[i];
        for(int i=;i<=rt;i++)Ne[L+i-+lt]=rx[i];//类似于归并那样重组
    if(!(l^r))return ;
    cdq(L,L+lt-,l,mid);
    cdq(L+lt,R,mid+,r);
    return ;
}
 
int IS(int x,int y){
    return a[x].x==a[y].x&&a[x].y==a[y].y&&a[x].z==a[y].z;
}
 
int res[];
 
int main()
{
    N=read(),K=read();
        for(int i=;i<=N;i++){
            a[i].x=read(),a[i].y=read(),a[i].z=read();
        }
    sort(a+,a+N+,cmp);
    a[].x=a[].y=a[].z=-2e9;
        for(int i=;i<=N;i++){
            if(IS(i,i-))++tot[cnt];
            else tot[++cnt]=,Ne[cnt]=a[i],Ne[cnt].o=cnt;
        }//去重
    cdq(,cnt,,K);//注意为cnt
        for(int i=;i<=cnt;i++)res[ans[i]+tot[i]-]+=tot[i];
        for(int i=;i<N;i++)printf("%d\n",res[i]);
    return ;
}

打开CDQ的大门&BZOJ3262的更多相关文章

  1. 文科生打开python的大门

    作为唯一的一名教育学院的学生,加入python课程,一定要声明我可不是并不是被迫选课的!虽然是文科生,但是是对编程这种东西很感兴趣的文科生.从站在python门口的张望,到现在悄悄把门打开,越来越感觉 ...

  2. 第一步,怎么打开react的大门?

    前言 其实我的react的实战经验很少,大概是17年-18年写了一个react全家桶的后台管理系统.猜测这个项目应该还一直在使用 在我手里的vue项目就比较多了,技术栈一直是vue全家桶.最近也在深入 ...

  3. 菜鸟VUER学习记——零0章、打开新的大门

    是什么 基于MVVM模型,核心库只关注视图层,通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件的js框架.根据项目的复杂度和需求,渐进的加入插件以达到恰到好处的程度. 解决问题 UI组件化 ...

  4. Python打开新世界的大门-入门篇1

    目录 题记 Python技巧.避坑及心得 八种数据类型 循环 函数 Homework 题外话 之前没有写博客的习惯,现在开始写觉得入门也太晚了吧,看看同龄的大哥都写了十几万字.于是 ...

  5. echart 打开新世界的大门

    实时折线图 option = { backgroundColor:'#2B2B2B', tooltip: { trigger: 'axis' }, legend: { data:['频率'], tex ...

  6. cdq分治入门--BZOJ3262: 陌上花开

    n<=100000个人,每个人三个属性Ai,Bi,Ci,一个人i的等级为Ai>=Aj,Bi>=Bj,Ci>=Cj的人数,求每个等级有多少人. 裸的三维偏序.按照常规思路,一维排 ...

  7. GoLang——Hello World,打开新世界的大门

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Go语言系列的第一篇文章,我们来聊聊这门新的语言和它的基础语法. 浅谈Golang 作为程序员而言,往往对于学习新的语言都是有抗拒的. ...

  8. bzoj 2163: 复杂的大门

    2163: 复杂的大门 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 418  Solved: 259[Submit][Status][Discuss ...

  9. BZOJ2163: 复杂的大门

    BZOJ2163: 复杂的大门 Description 你去找某bm玩,到了门口才发现要打开他家的大门不是一件容易的事……他家的大门外有n个站台,用1到n的正整数编号.你需要对每个站台访问一定次数以后 ...

随机推荐

  1. win10下vs2015配置Opencv3.1.0过程详解(转)

    下载安装Opencv3.1.0 下载Opencv3.1.0,进入官网,点击opencv for windows即可下载.  点击运行下载好的文件.实际上,opencv的安装程序就是解压缩文件,个人因为 ...

  2. Script:诊断解析等待和高version count

    select * from    (select sql_id, count(child_number)       from v$sql_shared_cursor      group by sq ...

  3. Oracle数据库突然宕机,处理方案

    一.现象 数据库突然断掉,无法响应,. 二.分析 查看日志发现错误如下(日志路径:D:\app\Administrator\diag\rdbms\orcl\orcl\trace\alert_hrpde ...

  4. 工作总结 [all]

    2. 工作总结 3. 面试经验 4. 其他

  5. 铁乐学python_day22_面向对象编程4

    以下内容大部分摘自博客http://www.cnblogs.com/Eva-J/ 封装 [封装]隐藏对象的属性和实现细节,仅对外提供公共访问方式. [好处] 将变化隔离: 便于使用: 提高复用性: 提 ...

  6. 关于 svn

    文章:http://www.cnblogs.com/xing901022/p/4403339.html 视频http://www.imooc.com/learn/109        7******* ...

  7. PHP利用二叉堆实现TopK-算法的方法详解

    前言 在以往工作或者面试的时候常会碰到一个问题,如何实现海量TopN,就是在一个非常大的结果集里面快速找到最大的前10或前100个数,同时要保证 内存和速度的效率,我们可能第一个想法就是利用排序,然后 ...

  8. UI(二)之正式过程

    2018-12-04 09:48:25 1.SetWindowsHookEx ·钩子实际上是一个处理消息的程序段,通过系统调用,把它挂入系统.每当特定的消息发出,在没有到达目的窗口前,钩子程序就先捕获 ...

  9. 【ansible】Windows开启远程控制错误解决方案:无法检查防火墙状态

    这个在老版本的Windows系统才有这种bug.例如Windows 2008 R2和Windows 7,如果你的系统的阿里云的Windows server 2008 R2,无需装这个,好像阿里云的系统 ...

  10. 【笔记】关于TCP三次握手和四次挥手的理解

    1. 三次握手: 服务器一定处于Listen状态,否则客户端发过来的连接会被拒绝.注:服务器和客户端的角色是相对的. 客户端发送第一次握手(客户端发送连接请求(SYNC包)到服务器)之后由Closed ...