原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ2141.html

题目传送门 - BZOJ2141

题意

  给定一个序列 $a$ ,先输出原先的逆序对数。

  然后 $m$ 次操作,每次交换两个数,并输出交换后的逆序对数。

  $1≤m≤2\times 10^3,1≤n≤2\times 10^4,1≤a_i≤10^9$

题解

  离散化。

  分个块。

  对于每一个前缀块和后缀块搞一个树状数组,维护一下每种值的个数的前缀和。

  考虑删除和增加操作,就是修改块内信息和统计块内块外信息。

  统计块内信息直接暴力。

  统计块外信息通过预处理的前缀块和后缀块树状数组来快速搞定。

  可以写一个子程序把四个东西压起来。

  但是我这样的做法需要注意一点:交换的两个数字在同一块内的时候,贡献会被算两遍。

代码

#include <bits/stdc++.h>
using namespace std;
const int N=20005;
int n,m,a[N],Ha[N],hs;
int Lv[45][N],Rv[45][N];
void HASH(){
sort(Ha+1,Ha+n+1);
hs=1;
for (int i=2;i<=n;i++)
if (Ha[i]!=Ha[i-1])
Ha[++hs]=Ha[i];
}
void add(int *c,int x,int d){
for (;x<=hs;x+=x&-x)
c[x]+=d;
}
int sum(int *c,int x){
int ans=0;
for (;x>0;x-=x&-x)
ans+=c[x];
return ans;
}
int Solve0(int *c,int *a,int n){
int ans=0;
for (int i=1;i<=n;i++){
ans+=sum(c,hs)-sum(c,a[i]);
add(c,a[i],1);
}
return ans;
}
int update(int x,int d){
int y=((x-1)>>10)+1,L=((y-1)<<10)+1,R=min(y<<10,n);
int ans=sum(Lv[y],hs)-sum(Lv[y],a[x])+sum(Rv[y],a[x]-1);
for (int i=L;i<x;i++)
if (a[i]>a[x])
ans++;
for (int i=R;i>x;i--)
if (a[i]<a[x])
ans++;
for (int i=1;i<y;i++)
add(Rv[i],a[x],d);
for (int i=y+1;((i-1)<<10)<n;i++)
add(Lv[i],a[x],d);
return ans*d;
}
int main(){
scanf("%d",&n);
for (int i=1;i<=n;i++)
scanf("%d",&a[i]),Ha[i]=a[i];
HASH();
for (int i=1;i<=n;i++)
a[i]=lower_bound(Ha+1,Ha+hs+1,a[i])-Ha;
int ans=Solve0(Lv[0],a,n);
memset(Lv,0,sizeof Lv);
memset(Rv,0,sizeof Rv);
for (int i=1;((i-1)<<10)<n;i++){
int L=((i-1)<<10)+1,R=min(i<<10,n);
for (int j=1;j<L;j++)
add(Lv[i],a[j],1);
for (int j=n;j>R;j--)
add(Rv[i],a[j],1);
}
scanf("%d",&m);
printf("%d\n",ans);
while (m--){
int x,y;
scanf("%d%d",&x,&y);
if (x>y)
swap(x,y);
ans+=update(x,-1);
ans+=update(y,-1);
if (((x-1)>>10)==((y-1)>>10)){
if (a[x]>a[y])
ans++;
if (a[y]>a[x])
ans--;
}
swap(a[x],a[y]);
ans+=update(x,1);
ans+=update(y,1);
printf("%d\n",ans);
}
return 0;
}

  

BZOJ2141 排队 树状数组 分块的更多相关文章

  1. 【BZOJ2141】排队 树状数组+分块

    [BZOJ2141]排队 Description 排排坐,吃果果,生果甜嗦嗦,大家笑呵呵.你一个,我一个,大的分给你,小的留给我,吃完果果唱支歌,大家乐和和.红星幼儿园的小朋友们排起了长长地队伍,准备 ...

  2. BZOJ2141排队——树状数组套权值线段树(带修改的主席树)

    题目描述 排排坐,吃果果,生果甜嗦嗦,大家笑呵呵.你一个,我一个,大的分给你,小的留给我,吃完果果唱支歌,大家 乐和和.红星幼儿园的小朋友们排起了长长地队伍,准备吃果果.不过因为小朋友们的身高有所区别 ...

  3. BZOJ_2141_排队_树状数组+分块

    BZOJ2141_排队_树状数组+分块 Description 排排坐,吃果果,生果甜嗦嗦,大家笑呵呵.你一个,我一个,大的分给你,小的留给我,吃完果果唱支歌,大家 乐和和.红星幼儿园的小朋友们排起了 ...

  4. 【bzoj4889】[Tjoi2017]不勤劳的图书管理员 树状数组+分块+二分

    题目描述(转自洛谷) 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度.现在有n本被打 ...

  5. bzoj 4765 普通计算姬(树状数组 + 分块)

    http://www.lydsy.com/JudgeOnline/problem.php?id=4765 很nice的一道题啊(可能是因为卡了n久终于做出来了 题意就是给你一棵带点权的有根树,sum( ...

  6. COGS.1822.[AHOI2013]作业(莫队 树状数组/分块)

    题目链接: COGS.BZOJ3236 Upd: 树状数组实现的是单点加 区间求和,采用值域分块可以\(O(1)\)修改\(O(sqrt(n))\)查询.同BZOJ3809. 莫队为\(O(n^{1. ...

  7. ACM-ICPC 2018 沈阳赛区网络预赛 J. Ka Chang(树状数组+分块)

    Given a rooted tree ( the root is node 1 ) of N nodes. Initially, each node has zero point. Then, yo ...

  8. Codeforces Round #404 (Div. 2) A,B,C,D,E 暴力,暴力,二分,范德蒙恒等式,树状数组+分块

    题目链接:http://codeforces.com/contest/785 A. Anton and Polyhedrons time limit per test 2 seconds memory ...

  9. gym 100589A queries on the Tree 树状数组 + 分块

    题目传送门 题目大意: 给定一颗根节点为1的树,有两种操作,第一种操作是将与根节点距离为L的节点权值全部加上val,第二个操作是查询以x为根节点的子树的权重. 思路: 思考后发现,以dfs序建立树状数 ...

随机推荐

  1. LabVIEW--为控件添加说明信息

    之前只知道为VI添加说明信息(在VI的属性里面添加,快捷键ctrl+I 打开),今天知道了控件也可以添加说明信息,这样就方便了许多,极大的提高了程序的可读性.

  2. 本地项目提交到github和提交更新(转)

    一:首先当然是去github注册账号了. 二:注册完毕登录后,在自己的首页上面点击右上角“+”号,然后选择New repository,或者直接点击下面的绿色按钮,创建一个新仓库.如图: 然后填入仓库 ...

  3. linux学习之uniq

    uniq最经常用的是统计次数,通常先排序,然后uniq  -c cat a.txt |sort -nr |uniq -c

  4. centos6.5 python命令行模式左右建无法使用

    我的虚拟机是centos6.5,自带python2.6:安装了Python2.7(安装了pip管理工具)后,在python2.7命令行模式下,左右键及退格键无法使用,基于以上情况,我进行了百度: 第一 ...

  5. 判断js数据类型的四种方法,以及各自的优缺点(转)

    转载地址:https://blog.csdn.net/lhjuejiang/article/details/79623973 数据类型分为基本类型和引用类型: 基本类型:String.Number.B ...

  6. a href=#与 a href=javascript:void(0) 的区别(转)

    a href="#"> 点击链接后,页面会向上滚到页首,# 默认锚点为 #TOP <a href="javascript:void(0)" onCl ...

  7. Confluence 6 从一个 XML 备份中导入一个空间

    有下面 2 中方法可以导入一个空间——通过上传一个文件,或者从你 Confluence 服务器上的一个目录中导入.上传文件仅仅是针对一个小站点的情况.为了取得最好的导入结果,我们推荐你从服务器上的目录 ...

  8. Java的家庭记账本程序(A)

    日期:2019.2.1 博客期:028 星期五 其实我早就开始开发“家庭记账本”的软件了,只不过写博客写的有点晚,我是打算先做web的!因为Android Studio的教程,还是要对应版本,好多问题 ...

  9. Spark Streaming 实现思路与模块概述

    一.基于 Spark 做 Spark Streaming 的思路 Spark Streaming 与 Spark Core 的关系可以用下面的经典部件图来表述: 在本节,我们先探讨一下基于 Spark ...

  10. ionic3 国际化

    http://www.cnblogs.com/huangenai/p/6868173.html 按上面这个网站的步骤整一遍, 但是ionic3 会报错  所以 在 import { NgModule ...