bzoj3289 Mato的文件管理 莫队+树状数组
求逆序对个数,莫队套树状数组
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#define N 50005
using namespace std;
int n,m,nn,a[N],c[5000005],be[N],maxn;
struct Query{
int l,r,id,ans;
}qr[N];
bool cmp1(Query a,Query b){
if(be[a.l]==be[b.l])
return a.r<b.r;
return be[a.l]<be[b.l];
}
bool cmp2(Query a,Query b){
return a.id<b.id;
}
int lowbit(int x){
return x&(-x);
}
void add(int x,int y){
while(x<=maxn)
{c[x]+=y;x+=lowbit(x);}
}
int query(int x){
int ans=0;
while(x)
{ans+=c[x];x-=lowbit(x);}
return ans;
}
void work(){
int l=1,r=0,tot=0;
for(int i=1;i<=m;i++){
while(l<qr[i].l){
tot-=query(a[l]-1);
add(a[l++],-1);
}
while(l>qr[i].l){
add(a[--l],1);
tot+=query(a[l]-1);
}
while(r<qr[i].r){
add(a[++r],1);
tot+=r-l+1-query(a[r]);
//printf("%d %d\n",query(a[r]),tot);
}
while(r>qr[i].r){
tot-=r-l+1-query(a[r]);
add(a[r--],-1);
}
qr[i].ans=tot;
}
}
int main()
{
scanf("%d",&n); nn=sqrt(n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
maxn=max(maxn,a[i]);
be[i]=(i-1)/nn+1;
}
scanf("%d",&m);
int l,r;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&l,&r);
qr[i].l=l; qr[i].r=r;
qr[i].id=i;
}
sort(qr+1,qr+m+1,cmp1);
work();
sort(qr+1,qr+m+1,cmp2);
for(int i=1;i<=m;i++)
printf("%d\n",qr[i].ans);
return 0;
}
bzoj3289 Mato的文件管理 莫队+树状数组的更多相关文章
- bzoj 3289: Mato的文件管理 莫队+树状数组
		3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description Mato同学 ... 
- BZOJ3289[JZYZOJP2018]: Mato的文件管理 莫队+树状数组+离散化
		描述 Description Mato同学从各路神犇以各种方式(你们懂的)收集了许多资料,这些资料一共有n份,每份有一个大小和一个编号.为了防止他人偷拷,这些资料都是加密过的, ... 
- 【BZOJ3289】Mato的文件管理 莫队+树状数组
		题目大意:给定一个长度为 N 的序列,M 个询问,每次询问区间逆序对的个数. 题解:用树状数组加速答案转移. 代码如下 #include <bits/stdc++.h> #define f ... 
- Bzoj 3289: Mato的文件管理  莫队,树状数组,逆序对,离散化,分块
		3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 1539 Solved: 665[Submit][Status][Di ... 
- bzoj 3289 : Mato的文件管理 (莫队+树状数组)
		题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=3289 思路: 求区间最小交换的次数将区间变成一个不降序列其实就是求区间逆序对的数量,这 ... 
- BZOJ_3289_Mato的文件管理_莫队+树状数组
		BZOJ_3289_Mato的文件管理_莫队+树状数组 Description Mato同学从各路神犇以各种方式(你们懂的)收集了许多资料,这些资料一共有n份,每份有一个大小和一个编号 .为了防止他人 ... 
- bzoj3236 作业 莫队+树状数组
		莫队+树状数组 #include<cstdio> #include<cstring> #include<iostream> #include<algorith ... 
- BZOJ3236[Ahoi2013]作业——莫队+树状数组/莫队+分块
		题目描述 输入 输出 样例输入 3 4 1 2 2 1 2 1 3 1 2 1 1 1 3 1 3 2 3 2 3 样例输出 2 2 1 1 3 2 2 1 提示 N=100000,M=1000000 ... 
- COGS.1822.[AHOI2013]作业(莫队 树状数组/分块)
		题目链接: COGS.BZOJ3236 Upd: 树状数组实现的是单点加 区间求和,采用值域分块可以\(O(1)\)修改\(O(sqrt(n))\)查询.同BZOJ3809. 莫队为\(O(n^{1. ... 
随机推荐
- minimun path sum(最小路径和)
			Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which ... 
- Java复习2.程序内存管理
			前言: 国庆节的第三天,大家都回家了,一个人在宿舍好无聊.不过这年头与其说是出去玩不如是说出去挤,所以在学校里还是清闲的好.找工作不用担心了,到时候看着你们慢慢忙:插个话题,大学都没有恋爱过,总之各种 ... 
- 信息化建设中的IT规划精要
			IT规划在信息化建设中发挥着"定位"和"导航"的作用,IT规划理论方法更是博大精深,细细讲来,会成为IT版本的"一千零一夜".因此,本文以& ... 
- JAVA学习总结-面向对象
			前言:java面向对象中的知识可以说是整个java基础最核心的部分,不知不觉已经学完快2个月了,是时候复习一波了,刚开始学习的时候被绕的很懵逼,这次总结完毕之后有了很多新的感悟,这就是所谓的每有会意, ... 
- 面向对象,更适合JavaScript
			面向对象程序设计是软件开发中一个很庞大很复杂的话题,它并不是仅仅学会类.继承.封装.多态这些面向对象编程语法元素就表示掌握的,这些语法元素只是实现面向对象程序的工具, 就像砖块.水泥能搭建小屋,也能造 ... 
- add-apt-repository出Exception问题
			参考:http://blog.sina.com.cn/s/blog_5388923c0100nu8h.html 症状: xxxx@xxxxx:~$ sudo add-apt-repository pp ... 
- JavaScript头像上传器的实现
			最近做这方面的东西,刚开始准备用一个开源项目:https://github.com/yueyoum/django-upload-avatar 后来发现这个开源组件的原设计者的定制化选项设计略显复杂,发 ... 
- ADT Android开发环境搭建小记
			1.之前因为产品方向原因,Android开发暂时搁浅,最近重新启动,SDK Manager.exe不能启动的话用启动\sdk\tools\adroid.bat即可启动SDK Manager.exe 2 ... 
- Oracle基础快速入门
			数据库体系结构 物理存储结构与Oracle启动时关系是 依次打开 参数(startup nomount).控制(startup mount).数据文件(open) 物理存储结构:指实际的文件存储形式 ... 
- 基于Python的数据分析:数据库索引效率探究
			索引在数据库中是一个很特殊的存在,它的目的就是为了提高数据查询得效率.同样,它也有弊端,更新一个带索引的表的时间比更新一个没有带索引的时间更长.有得有失.我希望做一些研究测试,搞清楚索引对于我们使用数 ... 
