【分块】【树状数组】bzoj3744 Gty的妹子序列
离散化,分块。
预处理出:ans[i][j] 第i块到第j块的逆序对数。
f[i][j] 第1~i块中大于j的数的个数。
g[i][j] 第1~j块中小于j的数的个数。
每次询问时对于整块部分可以O(1)获得。
对于零散部分呢?
>在一列数的后面添加一个数,逆序对数会增加 数列中比它大的数的个数。
>在一列数的前面添加一个数,逆序对数会增加 数列中比它小的数的个数。
所以统计以上信息的时候,对于整块的部分,我们可以借由预处理的东西差分来O(1)地获得答案,零散的部分就是树状数组咯。
空间复杂度是O(n*sqrt(n))的。
时间复杂度是O(n*sqrt(n)*log(n))的。
P.S.根本不用卡常数什么的呢。
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
#define N 50001
#define BLOCK_SIZE 250
int sz,sum,n,a[N],l[BLOCK_SIZE],r[BLOCK_SIZE],D[N],f[BLOCK_SIZE][BLOCK_SIZE];
int Less[BLOCK_SIZE][N],More[BLOCK_SIZE][N],b[N],en,m,x,y,num[N],ans;
struct Point{int v,p;}t[N];
bool operator < (const Point &a,const Point &b){return a.v<b.v;}
int Res,Num;char C,CH[];
inline int G()
{
Res=;C='*';
while(C<''||C>'')C=getchar();
while(C>=''&&C<=''){Res=Res*+(C-'');C=getchar();}
return Res;
}
inline void P(int x)
{
Num=;if(!x){putchar('');puts("");return;}
while(x>)CH[++Num]=x%,x/=;
while(Num)putchar(CH[Num--]+);
puts("");
}
void add(int p,const int &v) {while(p<=n) {D[p]+=v; p+=(p&(-p));}}
int getsum(int p) {int res=; while(p) {res+=D[p]; p-=(p&(-p));} return res;}
void makeblock()
{
sz=sqrt(n); if(!sz) sz=;
for(sum=;sum*sz<n;sum++)
{
l[sum]=r[sum-]+;
r[sum]=sum*sz;
for(int i=l[sum];i<=r[sum];i++) num[i]=sum;
}
l[sum]=r[sum-]+;
r[sum]=n;
for(int i=l[sum];i<=r[sum];i++) num[i]=sum;
}
void LiSan()
{
sort(t+,t+n+); a[t[].p]=++en;
for(int i=;i<=n;i++)
{
if(t[i].v!=t[i-].v) en++;
a[t[i].p]=en;
}
}
void init_each_ans()
{
for(int i=;i<=sum;i++)
{
memset(D,,sizeof(D)); int pos=,res=;
for(int j=i;j<=sum;j++)
{
for(int k=l[j];k<=r[j];k++)
{
pos++;
add(a[k],);
res+=(pos-getsum(a[k]));
}
f[i][j]=res;
}
} memset(D,,sizeof(D));
}
void init_sum()
{
memcpy(b,a,sizeof(b));
for(int i=;i<=sum;i++)
{
sort(b+l[i],b+r[i]+);
memcpy(More[i],More[i-],sizeof(More[i]));
memcpy(Less[i],Less[i-],sizeof(Less[i]));
for(int j=;j<=en;j++)
{
More[i][j]+=(b+r[i]+-upper_bound(b+l[i],b+r[i]+,j));
Less[i][j]+=(lower_bound(b+l[i],b+r[i]+,j)-(b+l[i]));
}
}
}
int getMore(const int &L,const int &R,const int &v){return More[R][v]-More[L-][v];}
int getLess(const int &L,const int &R,const int &v){return Less[R][v]-Less[L-][v];}
int main()
{
n=G();
for(int i=;i<=n;i++)
{
t[i].v=G();
t[i].p=i;
}
LiSan(); makeblock(); init_each_ans(); init_sum();
m=G();
for(int j=;j<=m;j++)
{
x=G(); y=G(); x^=ans; y^=ans;
if(num[x]+>=num[y])
{
int pos=; ans=;
for(int i=x;i<=y;i++)
{
pos++;
add(a[i],);
ans+=(pos-getsum(a[i]));
}
for(int i=x;i<=y;i++) add(a[i],-);
P(ans);
}
else
{
int pos=r[num[x]]-x+; ans=f[num[x]+][num[y]-];
for(int i=r[num[x]];i>=x;i--)
{
ans+=(getLess(num[x]+,num[y]-,a[i])+getsum(a[i]-));
add(a[i],);
}
for(int i=l[num[y]];i<=y;i++)
{
pos++;
add(a[i],);
ans+=(pos-getsum(a[i])+getMore(num[x]+,num[y]-,a[i]));
}
for(int i=x;i<=r[num[x]];i++) add(a[i],-);
for(int i=l[num[y]];i<=y;i++) add(a[i],-);
P(ans);
}
}
return ;
}
【分块】【树状数组】bzoj3744 Gty的妹子序列的更多相关文章
- 【bzoj3744】Gty的妹子序列 分块+树状数组+主席树
题目描述 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见…… 某天,蒟蒻Autumn发现了从 Gty的妹子树(bzoj3720) 上掉落下来了许多妹子,他发现 她们排成 ...
- 【BZOJ 3295】动态逆序对 - 分块+树状数组
题目描述 给定一个1~n的序列,然后m次删除元素,每次删除之前询问逆序对的个数. 分析:分块+树状数组 (PS:本题的CDQ分治解法见下一篇) 首先将序列分成T块,每一块开一个树状数组,并且先把最初的 ...
- 【bzoj2141】排队 分块+树状数组
题目描述 排排坐,吃果果,生果甜嗦嗦,大家笑呵呵.你一个,我一个,大的分给你,小的留给我,吃完果果唱支歌,大家乐和和.红星幼儿园的小朋友们排起了长长地队伍,准备吃果果.不过因为小朋友们的身高有所区别, ...
- 【分块+树状数组】codechef November Challenge 2014 .Chef and Churu
https://www.codechef.com/problems/FNCS [题意] [思路] 把n个函数分成√n块,预处理出每块中各个点(n个)被块中函数(√n个)覆盖的次数 查询时求前缀和,对于 ...
- 【BZOJ3744】Gty的妹子序列 分块+树状数组
[BZOJ3744]Gty的妹子序列 Description 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见…… 某天,蒟蒻Autumn发现了从 Gty的妹子树(bzo ...
- BZOJ3744 Gty的妹子序列(分块+树状数组)
题意 询问区间内逆序对数 强制在线 1<=n<=50000 1<=m<=50000 题解 两个预处理f[i][j]为块i到j的逆序对数,s[i][j]前i块≤j的有多少个边角 ...
- BZOJ3787:Gty的文艺妹子序列(分块,树状数组)
Description Autumn终于会求区间逆序对了!Bakser神犇决定再考验一下他,他说道: “在Gty的妹子序列里,某个妹子的美丽度可也是会变化的呢.你还能求出某个区间中妹子们美丽度的逆序对 ...
- BZOJ 3744: Gty的妹子序列 【分块 + 树状数组 + 主席树】
任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=3744 3744: Gty的妹子序列 Time Limit: 20 Sec Memory ...
- BZOJ 3744 Gty的妹子序列 (分块+树状数组+主席树)
题面传送门 题目大意:给你一个序列,多次询问,每次取出一段连续的子序列$[l,r]$,询问这段子序列的逆序对个数,强制在线 很熟悉的分块套路啊,和很多可持久化01Trie的题目类似,用分块预处理出贡献 ...
随机推荐
- echarts中图表过于靠左或靠右的情况解决办法。
经过好多次尝试,终于在http://blog.csdn.net/ainuser/article/details/76641963中得到解决. grid: { x: '30%', //相当于距离左边效果 ...
- Java实现十进制数转十六进制数
Now~Let's begin our second question~ 如何利用Java语言将十进制数字转换成十六进制数字呢? 我第一次编码出来的效果是酱紫的~ /** * */ package c ...
- JAVA多线程---好的博客资源收集
个人笔记,备忘 1.http://blog.csdn.net/column/details/concurrency.html 兰亭风雨的专栏 2.http://lavasoft.blog.51c ...
- vue入门知识
vue的特点在于:响应的数据绑定.组合的视图组件. vue的文件,分成三个部分<template>html模板</template> <script>js< ...
- 记另类Request method 'GET' not supported
一般遇到Request method 'GET' not supported这种问题,大家都会找相应controller下的具体方法,把get改为post之类.但是我这次是在访问静态资源,static ...
- Idea导入的工程看不到src等代码
问题描述: 从其他地方拷贝过来的工程,在本地导入到idea中时,展示如下的页面,里面的其他文件都看不到. 解决办法:(不知道是具体的什么原因引起的) 1. 关闭IDEA, 2.然后删除项目文件夹下的. ...
- 金中欢乐赛 A题
题目传送门 这道题就贪心.... 正的一坨和负的一坨间隔 #include<cstdio> #include<cstring> #include<algorithm> ...
- 为什么VS没有提供平win64程序编写项
最近在学习C++和MFC编程,突然有个疑问,为什么每次新建项目时,都只有win32 console application,从来没见过win64的选项,于是去网上查了查,下面是我找到的几个答案: 作者 ...
- [转]树莓派gpio口控制
0.前言 树莓派现在越来越火,网上树莓派的资料也越来越多.树莓派源自英国,国外嵌入式开源领域具有良好的分享精神,树莓派各种集成库也层出不穷,下面推荐几个. [[开发语言]——python [[ ...
- linux system函数分析
system函数是在应用编程里面想调用外部命令时最方便的方式了,除非想要获取命令行执行的输出信息, 那system就不行了,需要用popen.但是system内部具体怎么实现及怎么处理它的返回值经常被 ...