BZOJ 3295: [Cqoi2011]动态逆序对
3295: [Cqoi2011]动态逆序对
Time Limit: 10 Sec Memory Limit: 128 MB
Submit: 3865 Solved: 1298
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1
5
3
4
2
5
1
4
2
Sample Output
2
2
1
样例解释
(1,5,3,4,2)(1,3,4,2)(3,4,2)(3,2)(3)。
HINT
N<=100000 M<=50000
Source
树状数组套线段树
删除某个数,只要统计它之前还存在的比它大的数的个数,和之后还存在的比它小的数的个数
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
#define R register
using namespace std;
int read(){
R int x=;bool f=;
R char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=;ch=getchar();}
while(ch>=''&&ch<=''){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return f?x:-x;
}
const int N=1e5+;
const int M=N*;
int A[],B[];
int n,m,sz,num[N],pos[N],a1[N],a2[N],root[N],c[N];
int ls[M],rs[M],sum[M];
ll ans;
inline int lowbit(int x){
return x&-x;
}
void updata(int p,int v){
for(int i=p;i<=n;i+=lowbit(i)) c[i]+=v;
}
int query(int p){
int res=;
for(int i=p;i;i-=lowbit(i)) res+=c[i];
return res;
}
void update(int &y,int l,int r,int x){
if(!y) y=++sz;
sum[y]++;
if(l==r)return;
int mid=(l+r)>>;
if(x<=mid) update(ls[y],l,mid,x);
else update(rs[y],mid+,r,x);
}
int askmore(int x,int y,int num){
A[]=B[]=;int tmp=;x--;
for(int i=x;i;i-=lowbit(i)) A[++A[]]=root[i];
for(int i=y;i;i-=lowbit(i)) B[++B[]]=root[i];
int l=,r=n;
while(l!=r){
int mid=l+r>>;
if(num<=mid){
for(int i=;i<=A[];i++) tmp-=sum[rs[A[i]]];
for(int i=;i<=B[];i++) tmp+=sum[rs[B[i]]];
for(int i=;i<=A[];i++) A[i]=ls[A[i]];
for(int i=;i<=B[];i++) B[i]=ls[B[i]];
r=mid;
}
else{
for(int i=;i<=A[];i++) A[i]=rs[A[i]];
for(int i=;i<=B[];i++) B[i]=rs[B[i]];
l=mid+;
}
}
return tmp;
}
int askless(int x,int y,int num){
A[]=B[]=;int tmp=;x--;
for(int i=x;i;i-=lowbit(i)) A[++A[]]=root[i];
for(int i=y;i;i-=lowbit(i)) B[++B[]]=root[i];
int l=,r=n;
while(l!=r){
int mid=l+r>>;
if(num>mid){
for(int i=;i<=A[];i++) tmp-=sum[ls[A[i]]];
for(int i=;i<=B[];i++) tmp+=sum[ls[B[i]]];
for(int i=;i<=A[];i++) A[i]=rs[A[i]];
for(int i=;i<=B[];i++) B[i]=rs[B[i]];
l=mid+;
}
else{
for(int i=;i<=A[];i++) A[i]=ls[A[i]];
for(int i=;i<=B[];i++) B[i]=ls[B[i]];
r=mid;
}
}
return tmp;
}
int main(){
n=read();m=read();
for(int i=;i<=n;i++){
num[i]=read();pos[num[i]]=i;
a1[i]=query(n)-query(num[i]);
ans+=a1[i];
updata(num[i],);
}
memset(c,,sizeof c);
for(int i=n;i;i--){
a2[i]=query(num[i]-);
updata(num[i],);
}
for(int i=,x;i<=m;i++){
printf("%lld\n",ans);
x=read();x=pos[x];
ans-=(a1[x]+a2[x]-askmore(,x-,num[x])-askless(x+,n,num[x]));
for(int j=x;j<=n;j+=lowbit(j)) update(root[j],,n,num[x]);
}
return ;
}
BZOJ 3295: [Cqoi2011]动态逆序对的更多相关文章
- Bzoj 3295: [Cqoi2011]动态逆序对 分块,树状数组,逆序对
3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2886 Solved: 924[Submit][Stat ...
- bzoj 3295 [Cqoi2011]动态逆序对(cdq分治,BIT)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3295 [题意] n个元素依次删除m个元素,求删除元素之前序列有多少个逆序对. [思路] ...
- 【刷题】BZOJ 3295 [Cqoi2011]动态逆序对
Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计 ...
- bzoj 3295: [Cqoi2011]动态逆序对(树套树 or CDQ分治)
Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计 ...
- BZOJ 3295: [Cqoi2011]动态逆序对 [CDQ分治]
RT 传送门 首先可以看成倒着插入,求逆序对数 每个数分配时间(注意每个数都要一个时间)$t$,$x$位置,$y$数值 $CDQ(l,r)$时归并排序$x$ 然后用$[l,mid]$的加入更新$[mi ...
- BZOJ 3295 [CQOI2011]动态逆序对 (三维偏序CDQ+树状数组)
题目大意: 题面传送门 还是一道三维偏序题 每次操作都可以看成这样一个三元组 $<x,w,t>$ ,操作的位置,权值,修改时间 一开始的序列看成n次插入操作 我们先求出不删除时的逆序对总数 ...
- BZOJ 3295 [Cqoi2011]动态逆序对 ——CDQ分治
时间.位置.数字为三个属性. 排序时间,CDQ位置,树状数组处理数字即可. #include <cstdio> #include <cstring> #include < ...
- 【BZOJ 3295】动态逆序对 - 分块+树状数组
题目描述 给定一个1~n的序列,然后m次删除元素,每次删除之前询问逆序对的个数. 分析:分块+树状数组 (PS:本题的CDQ分治解法见下一篇) 首先将序列分成T块,每一块开一个树状数组,并且先把最初的 ...
- 【Bzoj 3295】 动态逆序对(树套树|CDQ分治)
[题意] 每次删除一个数,然后问删除前逆序对数. [分析] 没有AC不开心.. 我的树状数组套字母树,应该是爆空间的,空间复杂度O(nlogn^2)啊..哭.. 然后就没有然后了,别人家的树套树是树状 ...
随机推荐
- AES加密解密
AES简介 美国国家标准技术研究所在2001年发布了高级加密标准(AES).AES是一个对称分组密码算法,旨在取代DES成为广泛使用的标准. 根据使用的密码长度,AES最常见的有3种密钥方案,用以适应 ...
- 我曾经的第一个OC程序
一. OC简介 C语言的基础上,增加了一层最小的面向对象语法 完全兼容C语言 可以在OC代码中混入C语言代码,甚至是C++代码 可以使用OC开发Mac OS X平台和iOS平台的应用程序 二. OC语 ...
- JavaScript Patterns 5.8 Chaining Pattern
Chaining Pattern - Call methods on an object one after the other without assigning the return values ...
- JavaScript(二)——语法
1.基本数据类型: 字符串.小数.整数.日期时间.布尔型等. 2.类型转换: 分为自动转换和强制转换,一般用强制转换. 其他类型转换为整数:parseint(): 其他类型转换为小数:parseflo ...
- Spring,hibernate,struts的面试笔试题及答案
Hibernate工作原理及为什么要用? 原理: 1.读取并解析配置文件 2.读取并解析映射信息,创建SessionFactory 3.打开Sesssion 4.创建事务Transation ...
- js 获取json串中的值
用js中著名的eval函数var strJSON = "{name:'json name'}";//得到的JSONvar obj = eval( "(" + s ...
- WCF绑定和行为在普通应用和SilverLight应用一些对比
本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 阅读目录 介绍 绑定 普通应用和SilverLight应用区别 本文版权归mephisto和博客园共有, ...
- MySQL 调优基础(三) Linux文件系统
Linux的文件系统有点像MySQL的存储引擎,它支持各种各样的文件系统.它最上层是通过 virtual files system虚拟文件系统作为一个抽象接口层来对外提供调用的.然后下层的各种文件系统 ...
- mysql 触发器的创建 修改 删除
//做一个简单的练习,创建一个简单的触发器 完成添加文章的时候,自动加上时间,默认作者 为 ‘日记本的回忆‘ show columns from test; //查看表结构 //查看已存在触发器 sh ...
- n枚硬币问题(找假币)
问题描述: 在n枚外观相同的硬币中,有一枚是假币,并且已知假币与真币的重量不同,但不知道假币与真币相比较轻还是较重.可以通过一架天平来任意比较两组硬币,设计一个高效的算法来检测这枚假币. 解题思路: ...