BZOJ 3787 Gty的文艺妹子序列(分块+树状数组+前缀和)
题意
给出n个数,要求支持单点修改和区间逆序对,强制在线。
n,m<=50000
题解
和不带修改差不多,预处理出smaller[i][j]代表前i块小于j的数的数量,但不能用f[i][j]代表第i块到第j块逆序对的数量,这样不好维护。
我们用f[i][j]代表从第i块选出一个元素与从第j块选出一个元素组成逆序对的数量,维护时最多修改根号n个f数组,查询时用前缀和起到与不带修改时f数组的作用。
其他部分和不带修改时差不多。
然后问题就解决了。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const int N=;
int n,Block,a[N],block[N],L[],R[],tr1[][],tr[][N],ans,m;
int lowbit(int x){
return x&-x;
}
void add(int id,int x,int w){
for(int i=x;i<=n;i+=lowbit(i)){
tr[id][i]+=w;
}
}
int getsum(int id,int x){
int tmp=;
for(int i=x;i;i-=lowbit(i)){
tmp+=tr[id][i];
}
return tmp;
}
void add1(int id,int x,int w){
for(int i=x;i<=block[n];i+=lowbit(i)){
tr1[id][i]+=w;
}
}
int getsum1(int id,int x){
int tmp=;
for(int i=x;i;i-=lowbit(i)){
tmp+=tr1[id][i];
}
return tmp;
}
int main(){
scanf("%d",&n);Block=sqrt(n);
for(int i=;i<=n;i++){
scanf("%d",&a[i]);
block[i]=(i-)/Block+;
if(!L[block[i]])L[block[i]]=i;
R[block[i]]=i;
}
for(int i=;i<=block[n];i++)
for(int j=L[i];j<=n;j++){
add(i,a[j],);
}
for(int i=;i<=block[n];i++){
for(int j=L[i];j<=R[i];j++){
add(,a[j],);
add1(i,i,getsum(,n)-getsum(,a[j]));
}
for(int j=R[i]+;j<=n;j++){
add1(i,block[j],getsum(,n)-getsum(,a[j]));
}
for(int j=L[i];j<=R[i];j++){
add(,a[j],-);
}
}
scanf("%d",&m);
while(m--){
int k,x,y;
scanf("%d%d%d",&k,&x,&y);
x^=ans;y^=ans;
if(k==){
for(int i=;i<=block[x]-;i++){
int size=R[i]-L[i]+;
add1(i,block[x],size-(getsum(i,y)-getsum(i+,y))-(size-(getsum(i,a[x])-getsum(i+,a[x]))));
}
for(int i=block[x]+;i<=block[n];i++){
add1(block[x],i,getsum(i,y-)-getsum(i+,y-)-(getsum(i,a[x]-)-getsum(i+,a[x]-)));
}
for(int i=L[block[x]];i<=R[block[x]];i++){
add(,a[i],);
add1(block[x],block[x],-(getsum(,n)-getsum(,a[i])));
}
for(int i=L[block[x]];i<=R[block[x]];i++){
add(,a[i],-);
}
for(int i=;i<=block[x];i++){
add(i,a[x],-);add(i,y,);
}
a[x]=y;
for(int i=L[block[x]];i<=R[block[x]];i++){
add(,a[i],);
add1(block[x],block[x],getsum(,n)-getsum(,a[i]));
}
for(int i=L[block[x]];i<=R[block[x]];i++){
add(,a[i],-);
}
}
else{
if(block[x]+>=block[y]){
ans=;
for(int i=x;i<=y;i++){
add(,a[i],);
ans+=getsum(,n)-getsum(,a[i]);
}
for(int i=x;i<=y;i++){
add(,a[i],-);
}
printf("%d\n",ans);
}
else{
ans=;
for(int i=block[x]+;i<=block[y]-;i++){
ans+=getsum1(i,block[y]-);
}
for(int i=x;i<=R[block[x]];i++){
add(,a[i],);
ans+=getsum(,n)-getsum(,a[i]);
ans+=getsum(block[x]+,a[i]-)-getsum(block[y],a[i]-);
}
for(int i=L[block[y]];i<=y;i++){
add(,a[i],);
ans+=getsum(,n)-getsum(,a[i]);
ans+=getsum(block[x]+,n)-getsum(block[y],n)-(getsum(block[x]+,a[i])-getsum(block[y],a[i]));
}
for(int i=x;i<=R[block[x]];i++){
add(,a[i],-);
}
for(int i=L[block[y]];i<=y;i++){
add(,a[i],-);
}
printf("%d\n",ans);
}
}
}
return ;
}
BZOJ 3787 Gty的文艺妹子序列(分块+树状数组+前缀和)的更多相关文章
- BZOJ 3787: Gty的文艺妹子序列 [分块 树状数组!]
传送门 题意:单点修改,询问区间内逆序对数,强制在线 看到加了!就说明花了不少时间.... 如果和上题一样预处理信息,用$f[i][j]$表示块i到j的逆序对数 强行修改的话,每个修改最多会修改$(\ ...
- BZOJ3787:Gty的文艺妹子序列(分块,树状数组)
Description Autumn终于会求区间逆序对了!Bakser神犇决定再考验一下他,他说道: “在Gty的妹子序列里,某个妹子的美丽度可也是会变化的呢.你还能求出某个区间中妹子们美丽度的逆序对 ...
- BZOJ3787 gty的文艺妹子序列 【树状数组】【分块】
题目分析: 首先这种乱七八糟的题目就分块.然后考虑逆序对的统计. 一是块内的,二是块之间的,三是一个块内一个块外,四是都在块外. 令分块大小为$S$. 块内的容易维护,单次维护时间是$O(S)$. 块 ...
- BZOJ 3787: Gty的文艺妹子序列
3787: Gty的文艺妹子序列 Time Limit: 50 Sec Memory Limit: 256 MBSubmit: 186 Solved: 58[Submit][Status][Dis ...
- 【bzoj3744】Gty的妹子序列 分块+树状数组+主席树
题目描述 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见…… 某天,蒟蒻Autumn发现了从 Gty的妹子树(bzoj3720) 上掉落下来了许多妹子,他发现 她们排成 ...
- BZOJ 3744 Gty的妹子序列 (分块+树状数组+主席树)
题面传送门 题目大意:给你一个序列,多次询问,每次取出一段连续的子序列$[l,r]$,询问这段子序列的逆序对个数,强制在线 很熟悉的分块套路啊,和很多可持久化01Trie的题目类似,用分块预处理出贡献 ...
- 【BZOJ3744】Gty的妹子序列 分块+树状数组
[BZOJ3744]Gty的妹子序列 Description 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见…… 某天,蒟蒻Autumn发现了从 Gty的妹子树(bzo ...
- BZOJ 3744 Gty的妹子序列 分块+树状数组
具体分析见 搬来大佬博客 时间复杂度 O(nnlogn)O(n\sqrt nlogn)O(nnlogn) CODE #include <cmath> #include <cctyp ...
- BZOJ 4765 普通计算姬 dfs序+分块+树状数组+好题!!!
真是道好题...感到灵魂的升华... 按dfs序建树状数组,拿前缀和去求解散块: 按点的标号分块,分成一个个区间,记录区间子树和 的 总和... 具体地,需要记录每个点u修改后,对每一个块i的贡献,记 ...
随机推荐
- Elasticsearch之中文分词器插件es-ik的自定义热更新词库
不多说,直接上干货! 欢迎大家,关注微信扫码并加入我的4个微信公众号: 大数据躺过的坑 Java从入门到架构师 人工智能躺过的坑 Java全栈大联盟 ...
- C#~异步编程再续~你必须要知道的ThreadPool里的throw
问题依旧存在 之前写过相关文章异步编程的文章,本文主要还是一点补充,之前在IIS经常发w3wp进程无做挂了的情况,但一直没能找到真正的原因,而查找相关资料,找了一些相关的文章,如await和async ...
- select标签下option标签里value属性有什么用以及和text的区别
转自:http://blog.csdn.net/summer_sy/article/details/54572398 1:value的用处 <select > <option val ...
- String Comparison(C#)
When comparing programmatic strings, you should always use StringComparison.Ordinal or StringCompari ...
- PCL例程调试错误之缺少flann-config.cmake
编译环境和PCL版本为:win7-x64 + MSVC2013 + PCL1.8.0-win32-MSVC2013. 调试PCL官网例程Cluster Recognition and 6DOF Pos ...
- SLAM概念学习之特征图Feature Maps
特征图(或者叫地标图,landmark maps)利用参数化特征(如点和线)的全局位置来表示环境.如图1所示,机器人的外部环境被一些列参数化的特征,即二维坐标点表示.这些静态的地标点被观测器(装有传感 ...
- 强化学习(3)-----DQN
看这篇https://blog.csdn.net/qq_16234613/article/details/80268564 1.DQN 原因:在普通的Q-learning中,当状态和动作空间是离散且维 ...
- 不实例化一个 class 的时候使用它的property
class A: @property def name(self): " print(A.name) # <property object at 0x10d54cf98> cla ...
- Python中编写精美图形界面(PyQt5)
纯代码,布局的讲解 见: https://cloud.tencent.com/developer/article/1345469 Qt designer设计文件 .ui转 .py文件,进阶使用 注:不 ...
- input标签type为number时,输入小数,在Firefox浏览器上输入框标红的问题
问题一:firefox 下 默认情况 <input type="number"> 只允许输入整数,输入小数时会报错,输入框被标红 这时候可以添加参数 step=&q ...