RT

传送门


首先可以看成倒着插入,求逆序对数

每个数分配时间(注意每个数都要一个时间)$t$,$x$位置,$y$数值

$CDQ(l,r)$时归并排序$x$

然后用$[l,mid]$的加入更新$[mid+1,r]$的查询(其实每个数就是一个插入一个查询)

这里就是前后求逆序对,用树状数组

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const int N=2e5+;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int n,m;
int mp[N];
struct Operation{
int t,x,y;
Operation(){}
Operation(int t,int id,int v):t(t),x(id),y(v){}
bool operator <(const Operation &r)const{
return x==r.x ? y<r.y : x<r.x;
}
}a[N],t[N];
inline bool cmpTime(const Operation &a,const Operation &b){
return a.t==b.t ? a.x<b.x : a.t<b.t;
}
int c[N];
inline int lowbit(int x){return x&-x;}
inline void add(int p,int v){for(;p<=n;p+=lowbit(p)) c[p]+=v;}
inline int sum(int p){
int re=;
for(;p;p-=lowbit(p)) re+=c[p];
return re;
}
ll ans[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]<a[j])) add(a[i].y,),t[p++]=a[i++];
else ans[a[j].t]+=sum(n)-sum(a[j].y),t[p++]=a[j++];
}
for(int i=l;i<=mid;i++) add(a[i].y,-);
for(int i=l;i<=r;i++) a[i]=t[i];
for(int i=r;i>=l;i--){
if(a[i].t<=mid) add(a[i].y,);
else ans[a[i].t]+=sum(a[i].y);
}
for(int i=l;i<=r;i++) if(a[i].t<=mid) add(a[i].y,-);
}
int main(){
//freopen("inverse.in","r",stdin);
//freopen("inverse.out","w",stdout);
n=read();m=read();
for(int i=;i<=n;i++) a[i]=Operation(,i,read()),mp[a[i].y]=i;
int Tim=n;
for(int i=;i<=m;i++) a[mp[read()]].t=Tim--;
for(int i=;i<=n;i++) if(!a[i].t) a[i].t=Tim--;
sort(a+,a++n,cmpTime);
//for(int i=1;i<=10;i++) printf("hi %d %d %d\n",i,a[i].t,a[i].y);
CDQ(,n);
//for(int i=1;i<=10;i++) printf("ans %d %d\n",i,ans[i]);
for(int i=;i<=n;i++) ans[i]+=ans[i-];
for(int i=n;i>=n-m+;i--) printf("%lld\n",ans[i]);
}

【update 2017-03-17】

前两天学到了删除的姿势,逆序对问题的删除操作不用时间倒流也可以,直接减去它形成的逆序对数并且在树状数组中删除就可以了

虽然慢一些但是清晰多了

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const int N=2e5+;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} int n,Q,a[N],pos[N],x;
int m,tim;
struct meow{
int t,x,y,type,qid;
meow(){}
meow(int a,int b,int c,int d,int e=):t(a),x(b),y(c),type(d),qid(e){}
bool operator <(const meow &r) const{
return x==r.x ? y<r.y : x<r.x;
}
}q[N],t[N];
ll ans[N]; int c[N];
inline void add(int p,int v) {for(;p<=n;p+=(p&-p)) c[p]+=v;}
inline int sum(int p) {int re=; for(;p;p-=(p&-p)) re+=c[p]; return re;} void CDQ(int l,int r){
if(l==r) return;
int mid=(l+r)>>;
for(int i=l;i<=r;i++){
if(q[i].t<=mid) add(q[i].y,q[i].type);
else ans[q[i].qid]+= q[i].type*( sum(n)-sum(q[i].y) );
}
for(int i=l;i<=r;i++) if(q[i].t<=mid) add(q[i].y,-q[i].type); for(int i=r;i>=l;i--){
if(q[i].t<=mid) add(q[i].y,q[i].type);
else ans[q[i].qid]+= q[i].type*sum(q[i].y-);
}
for(int i=l;i<=r;i++) if(q[i].t<=mid) add(q[i].y,-q[i].type); int p1=l,p2=mid+;
for(int i=l;i<=r;i++){
if(q[i].t<=mid) t[p1++]=q[i];
else t[p2++]=q[i];
}
for(int i=l;i<=r;i++) q[i]=t[i];
CDQ(l,mid); CDQ(mid+,r);
} int main(){
freopen("in","r",stdin);
n=read(); Q=read();
for(int i=;i<=n;i++) a[i]=read(), pos[a[i]]=i, q[++m]=meow(++tim, i, a[i], , ); for(int i=;i<=Q;i++) x=read(), q[++m]=meow(++tim, pos[x], x, -, i);
sort(q+, q++m);
CDQ(,m);
for(int i=;i<=Q;i++) ans[i]+=ans[i-],printf("%lld\n",ans[i-]);
}

BZOJ 3295: [Cqoi2011]动态逆序对 [CDQ分治]的更多相关文章

  1. BZOJ 3295 [Cqoi2011]动态逆序对 ——CDQ分治

    时间.位置.数字为三个属性. 排序时间,CDQ位置,树状数组处理数字即可. #include <cstdio> #include <cstring> #include < ...

  2. Bzoj 3295: [Cqoi2011]动态逆序对 分块,树状数组,逆序对

    3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2886  Solved: 924[Submit][Stat ...

  3. [BZOJ3295][Cqoi2011]动态逆序对 CDQ分治&树套树

    3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec  Memory Limit: 128 MB Description 对于序列A,它的逆序对数定义为满足i<j,且 ...

  4. bzoj3295: [Cqoi2011]动态逆序对(cdq分治+树状数组)

    3295: [Cqoi2011]动态逆序对 题目:传送门 题解: 刚学完cdq分治,想起来之前有一道是树套树的题目可以用cdq分治来做...尝试一波 还是太弱了...想到了要做两次cdq...然后伏地 ...

  5. BZOJ3295 [Cqoi2011]动态逆序对 —— CDQ分治

    题目链接:https://vjudge.net/problem/HYSBZ-3295 3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec  Memory Limit: 1 ...

  6. BZOJ 3295: [Cqoi2011]动态逆序对

    3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3865  Solved: 1298[Submit][Sta ...

  7. 【BZOJ3295】[Cqoi2011]动态逆序对 cdq分治

    [BZOJ3295][Cqoi2011]动态逆序对 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依 ...

  8. bzoj 3295 [Cqoi2011]动态逆序对(cdq分治,BIT)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3295 [题意] n个元素依次删除m个元素,求删除元素之前序列有多少个逆序对. [思路] ...

  9. bzoj 3295: [Cqoi2011]动态逆序对(树套树 or CDQ分治)

    Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计 ...

随机推荐

  1. A. Two Bases

    A. Two Bases time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  2. 克鲁斯卡尔(Kruskal)算法求最小生成树

    /* *Kruskal算法求MST */ #include <iostream> #include <cstdio> #include <cstring> #inc ...

  3. Spark环境搭建(上)——基础环境搭建

    Spark摘说 Spark的环境搭建涉及三个部分,一是linux系统基础环境搭建,二是Hadoop集群安装,三是Spark集群安装.在这里,主要介绍Spark在Centos系统上的准备工作--linu ...

  4. Linux 用户组及用户管理

    查看所有组的信息:(信息保存在/etc/group文件中) 其中每段信息用:分割 ,每段的含义如下: 用户名组名:密码:用户组的id:用户组所包含的用户(多个用户用,分割) 查看所有的用户信息:(信息 ...

  5. [国嵌笔记][008-009][远程登录Linux]

    [国嵌笔记][008][远程登录Linux] 1.windows与Linux能够相互ping通 2.关闭Linux防火墙 /etc/init.d/iptables stop 3.通过ssh(字符界面) ...

  6. J.U.C JMM. pipeline.指令重排序,happen-before(续)

    前面已经介绍硬件平台Cache Coherence问题和解决办法,下面来看看Java虚拟机平台的相关知识.硬件平台处理器,高速缓存,主存之间的交互关系如下: Java内存模型(JMM)         ...

  7. ublime Text 3安装与使用

    ublime Text 3安装与使用 工具 2015-07-30 10:46 0 34 工欲善其事,必先利其器.好的工具帮助我们节省大量的工作时间,好用的插件使工具更强大. 1. 下载 可以从官网 h ...

  8. Java 获得Class的绝对路径方法

    Java获得class文件的绝对路径:1.e.g. Foo.class => Foo.class.getResuorce("").getFile(); 该方法在eclipse ...

  9. 在Spring Boot中使用swagger-bootstrap-ui

    在Spring Boot中使用swagger-bootstrap-ui swagger-bootstrap-ui是基于swagger接口api实现的一套UI,因swagger原生ui是上下结构的,在浏 ...

  10. SpringMvc4.x--Spring MVC的常用注解

    //下列代码显示用到的对象public class DemoObj { private Long id; private String name; public DemoObj() { //① sup ...