原文链接http://www.cnblogs.com/zhouzhendong/p/8678185.html

题目传送门 - BZOJ3295

题意

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

题解

  我们首先把原题目转化成依次加入数字求总逆序对个数。

  假设某一个数字被加入的时间为$t$,他的位置为$id$,它的值为$v$。

  则存在两种情况,使得$i$能更新$j$。

  $Situation 1:$

  $t_i<t_j,id_i<id_j,v_i>v_j$

  $Situation 2:$

  $t_i<t_j,id_i>id_j,v_i<v_j$

  于是机智的你是不是发现CDQ分治一下就秒掉了???

  (其实这题如果用带修改的主席树或者树套树貌似脑子都不用动…………)

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=100005;
struct Node{
int id,v,t,res;
}a[N],b[N];
int n,m,pos[N],tree[N];
LL res[N];
int lowbit(int x){
return x&-x;
}
void add(int x,int y){
for (;x<=n;x+=lowbit(x))
tree[x]+=y;
}
int sum(int x){
int ans=0;
for (;x>0;x-=lowbit(x))
ans+=tree[x];
return ans;
}
void CDQ(int L,int R){
if (L==R)
return;
int mid=(L+R)>>1;
for (int i=L,l=L,r=mid+1;i<=R;i++)
if (a[i].t<=mid)
b[l++]=a[i];
else
b[r++]=a[i];
for (int i=L;i<=R;i++)
a[i]=b[i];
int j=L;
for (int i=mid+1;i<=R;i++){
while (j<=mid&&a[j].id<a[i].id)
add(n+1-a[j].v,1),j++;
a[i].res+=sum(n+1-a[i].v);
}
for (int i=L;i<j;i++)
add(n+1-a[i].v,-1);
j=mid;
for (int i=R;i>mid;i--){
while (j>=L&&a[j].id>a[i].id)
add(a[j].v,1),j--;
a[i].res+=sum(a[i].v);
}
for (int i=mid;i>j;i--)
add(a[i].v,-1);
CDQ(L,mid),CDQ(mid+1,R);
}
int main(){
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++){
scanf("%d",&a[i].v);
a[i].id=pos[a[i].v]=i;
a[i].t=a[i].res=0;
}
for (int i=1,x;i<=m;i++){
scanf("%d",&x);
a[pos[x]].t=n-i+1;
}
for (int i=1,t=n-m;i<=n;i++)
if (!a[i].t)
a[i].t=t--;
memset(tree,0,sizeof tree);
CDQ(1,n);
memset(res,0,sizeof res);
for (int i=1;i<=n;i++)
res[a[i].t]+=a[i].res;
for (int i=2;i<=n;i++)
res[i]+=res[i-1];
for (int i=n;i>n-m;i--)
printf("%lld\n",res[i]);
return 0;
}

  

BZOJ3295 [Cqoi2011]动态逆序对 分治 树状数组的更多相关文章

  1. bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组

    [bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ...

  2. BZOJ3295: [Cqoi2011]动态逆序对(树状数组套主席树)

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

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

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

  4. P3157 [CQOI2011]动态逆序对(树状数组套线段树)

    P3157 [CQOI2011]动态逆序对 树状数组套线段树 静态逆序对咋做?树状数组(别管归并QWQ) 然鹅动态的咋做? 我们考虑每次删除一个元素. 减去的就是与这个元素有关的逆序对数,介个可以预处 ...

  5. BZOJ3295 动态逆序对(树状数组套线段树)

    [Cqoi2011]动态逆序对 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 6058  Solved: 2117[Submit][Status][D ...

  6. bzoj3295: [Cqoi2011]动态逆序对(树套树)

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  7. 【BZOJ 3295】动态逆序对 - 分块+树状数组

    题目描述 给定一个1~n的序列,然后m次删除元素,每次删除之前询问逆序对的个数. 分析:分块+树状数组 (PS:本题的CDQ分治解法见下一篇) 首先将序列分成T块,每一块开一个树状数组,并且先把最初的 ...

  8. 【Luogu】P3157动态逆序对(树状数组套主席树)

    题目链接 md第一道在NOILinux 下用vim做的紫题.由于我对这个操作系统不是很熟悉,似乎有什么地方搞错了,md调死.(我还打了两遍代码,调了两个小时) 但是这道题并不难,就是树状数组套上主席树 ...

  9. AcWing 107. 超快速排序(归并排序 + 逆序对 or 树状数组)

    在这个问题中,您必须分析特定的排序算法----超快速排序. 该算法通过交换两个相邻的序列元素来处理n个不同整数的序列,直到序列按升序排序. 对于输入序列9 1 0 5 4,超快速排序生成输出0 1 4 ...

随机推荐

  1. appium+java(五)微信小程序自动化测试实践

    前言: 上一篇<appium+java(四)微信公众号自动化测试实践>中,尝试使用appium实现微信公众号自动化测试,接着尝试小程序自动化,以学院小程序为例 准备工作 1.java-cl ...

  2. HTTP连接池

    <context:property-placeholder location="classpath:conf/framework/httpclient.properties" ...

  3. VUE 生成二维码(qrcodejs)

    1. 概述 1.1 引入二维码生成模块 npm install qrcodejs2 --save 注意:此处安装qrcodejs2,安装依赖后可在main方法中进行全局引用设置,也可单独某个页面中进行 ...

  4. robot启动

    可以这句写入到bat文件里 pythonw.exe -c "from robotide import main; main()"

  5. 使用Eclipse进行Makefile项目

    最近在MCU on Eclipse网站上看到Erich Styger所写的一篇有关在Eclipse中使用Makefile创建项目的文章,文章讲解清晰明了非常不错,所以呢没人将其翻译过来供各位同仁参考. ...

  6. 移动端点击出现阴影 css解决方案

    a,img,button,input,textarea,div{-webkit-tap-highlight-color:rgba(255,255,255,0);}

  7. Android UiAutomator2.0

    一.环境搭建 JDK(java环境).SDK(adb appt环境),这两个已经不想再叙述了直接看详见--> android studio 安装,下载地址:https://developer.a ...

  8. git使用中出现的错误

    因同时有两个git账户,之前登录了git A 用户在使用了 1.       长期存储密码 git config --global credential.helper store 之后在git B 账 ...

  9. ajax执行成功后,在success回调函数中把后台返回的list还原到html的table中

    需求描述:前台通过onclick触发ajax,到后台返回一个list(json格式的),把list插入到html的table中. 思路简介: ̄□ ̄|| 刚开始的时候,是没有思路的,就卡在了,怎么把 a ...

  10. select下拉框的数据回显

    需求描述:select框,下拉后又很多的选项,选择一个,根绝后台代码做查询,完成之后,页面上的select框还是之前选的那个值 解决思路:select本质就是 value和text一一对应,根据你的s ...