BZOJ3289[JZYZOJP2018]: Mato的文件管理 莫队+树状数组+离散化
 
 
 
 
  | 
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
离散化可以看我上一篇写的那个离散化blahblah什么的.......算是莫队板子
和离散化板子和树状数组板子放到一起的板子题....
树状数组求逆序对即可
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int n,q;
int a[]={};//原本的文件
int b[]={};//离散化媒介
int bel[]={};//询问块
int tr[]={};//树状数组
int ans[]={};
struct nod{
int x,y;
int id;
}e[];
int sz;
bool mmp(nod aa,nod bb){
if(bel[aa.x]==bel[bb.x]){
if(aa.y==bb.y){
return aa.x<bb.x;
}
return aa.y<bb.y;
}
return bel[aa.x]<bel[bb.x];
}
inline int lowbit(int x){
return x&-x;
}
inline int sum(int x){
int ret = ;
while(x>){
ret+=tr[x];
x-=lowbit(x);
}
return ret;
}
inline void add(int x,int v){
while(x<=){
tr[x]+=v;
x+=lowbit(x);
}
}
void work(){
int l=,r=;
int an=;
for(int i=;i<=q;i++){
while(l>e[i].x){
l--;
an+=sum(a[l]-);
add(a[l],);
}
while(r<e[i].y){
r++;
an+=sum()-sum(a[r]);
add(a[r],);
}
while(l<e[i].x){
add(a[l],-);
an-=sum(a[l]-);
l++;
}
while(r>e[i].y){
add(a[r],-);
an-=sum()-sum(a[r]);
r--;
}
ans[e[i].id]=an;
}
for(int i=;i<=q;i++){
printf("%d\n",ans[i]);
}
}
int main(){
//freopen("wtf.in","r",stdin);
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%d",&a[i]);
b[i]=a[i];
}
sort(b+,b+n+);
int size=unique(b+,b+n+)-b-;
for(int i=;i<=n;i++){
a[i]=lower_bound(b+,b+size+,a[i])-b;
}
scanf("%d",&q);
sz=(int)sqrt((double)q);
for(int i=;i<=q;i++){
bel[i]=(i-)/sz+;
}
for(int i=;i<=q;i++){
scanf("%d%d",&e[i].x,&e[i].y);
e[i].id=i;
}
sort(e+,e++q,mmp);
work();
return ;
}
BZOJ3289[JZYZOJP2018]: Mato的文件管理 莫队+树状数组+离散化的更多相关文章
- 【BZOJ3289】Mato的文件管理 莫队+树状数组
		
题目大意:给定一个长度为 N 的序列,M 个询问,每次询问区间逆序对的个数. 题解:用树状数组加速答案转移. 代码如下 #include <bits/stdc++.h> #define f ...
 - bzoj 3289: Mato的文件管理 莫队+树状数组
		
3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description Mato同学 ...
 - bzoj3289 Mato的文件管理 莫队+树状数组
		
求逆序对个数,莫队套树状数组 #include<cstdio> #include<iostream> #include<cstring> #include<c ...
 - 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. ...
 
随机推荐
- js和php的时间戳和时间的转化
			
js时间戳转化为时间 //时间戳转时间 function time(sj) { var now = new Date(sj*1000); var year =now.getFullYear(); va ...
 - mysql-connector-python取二进制字节时报错UnicodeDecodeError:'utf-8' codec can't decode byte 0xb0 in position 0
			
在储存用户密码时,我使用了hmac算法对用户密码加密,加密出来的hash值是一个二进制字节串,我把这个字节串存到mysql的password字段,password字段的数据类型是varbinary. ...
 - 浅析linux内核中timer定时器的生成和sofirq软中断调用流程(转自http://blog.chinaunix.net/uid-20564848-id-73480.html)
			
浅析linux内核中timer定时器的生成和sofirq软中断调用流程 mod_timer添加的定时器timer在内核的软中断中发生调用,__run_timers会spin_lock_irq(& ...
 - java中8种数据类型和默认值所占字节数
			
java 8种基本数据类型的默认值及所占字节数 通过一段代码来测试一下 8种基本数据类型的默认值 1 package dierge; 2 3 public class Ceshi { 4 int a; ...
 - kvm安装准备
			
到实际情况下,做虚拟化是直接做在真机上. 但实验时,可以在虚拟机上进行.(因为做实验的时候没办法连接到桥接模式的网络,所以使用了NAT方式来连接网络) 在vmware安装centos 64bit fo ...
 - javaScript如何跳出多重循环break、continue
			
先来说说break和continue之间的区别 for(var i=0;i<10;i++){ if(i>5){ break; }}console.log(i); ---6 •当i ...
 - Sublime Text 2之Emmet插件安装及使用
			
1.安装Emmet How To Install?Reffer to this link:http://www.ituring.com.cn/article/47310 2.使用Emmet--Abbr ...
 - AXFR和IXFR区域传输及原理
			
由于区域在DNS中发挥着重要的作用,因此希望在网络上的多个DNS服务器中提供区域,以提供解析名称查询时的可用性和容错.否则,如果使用单个服务器而该服务器没有响应,则该区域中的名称查询会失败.对于主要区 ...
 - Redis学习-redis概述
			
最近刚刚接触了redis技术,对此有一些了解,这是简单做一点总结. Redis简介 首先,简单了解一下NoSQL(Not only sql),不要错误的理解为:没有SQL,而是不仅仅是SQL.NoSQ ...
 - [你必须知道的.NET]第二十四回:认识元数据和IL(上)
			
发布日期:2009.02.24 作者:Anytao © 2009 Anytao.com ,Anytao原创作品,转贴请注明作者和出处. 说在,开篇之前 很早就有说说Metadata(元数据)和IL(中 ...