BZOJ3744: Gty的妹子序列

https://lydsy.com/JudgeOnline/problem.php?id=3744

分析:

  • 预处理出来每一块块首到所有位置的逆序对数。
  • 查询时主席树上查即可。
  • 卡常

代码:

#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm>
#include <cmath>
using namespace std;
#define N 60050
typedef int ll;
int n,a[N],m;
int blo,size,L[N],R[N],pos[N];
int siz[N*23],ls[N*23],rs[N*23],cnt,V[N],ln,root[N];
ll ansblo[305][N];
void update(int l,int r,int x,int &p,int q) {
p=++cnt; siz[p]=siz[q]+1; ls[p]=ls[q]; rs[p]=rs[q];
if(l==r) return ;
int mid=(l+r)>>1;
if(x<=mid) update(l,mid,x,ls[p],ls[q]);
else update(mid+1,r,x,rs[p],rs[q]);
}
int qmnx(int l,int r,int x,int p,int q) {
if(l==r) return l<=x?siz[q]-siz[p]:0;
int mid=(l+r)>>1;
if(x<=mid) return qmnx(l,mid,x,ls[p],ls[q]);
else return qmnx(mid+1,r,x,rs[p],rs[q])+siz[ls[q]]-siz[ls[p]];
}
int qmxx(int l,int r,int x,int p,int q) {
if(l==r) return l>=x?siz[q]-siz[p]:0;
int mid=(l+r)>>1;
if(x<=mid) return qmxx(l,mid,x,ls[p],ls[q])+siz[rs[q]]-siz[rs[p]];
else return qmxx(mid+1,r,x,rs[p],rs[q]);
}
ll work(int x,int y) {
int p=pos[x],q=pos[y],i;
ll re=0;
if(p==q) {
for(i=x+1;i<=y;i++) {
re+=qmxx(1,ln,a[i]+1,root[x-1],root[i-1]);
}
return re;
}
re=ansblo[p+1][y];
for(i=R[p];i>=x;i--) {
re+=qmnx(1,ln,a[i]-1,root[i],root[y]);
}
return re;
}
int s[N];
void fix(int x){for(;x<=ln;x+=x&-x)s[x]++;}
int find(int x){int ret=0;for(;x;x-=x&-x)ret+=s[x];return ret;}
int main() {
///////////////////////////////////////////////////////////////////////////////////////////////
///*////////////////*/freopen("noon.in","r",stdin); freopen("noon.out","w",stdout);//////////////
///////////////////////////////////////////////////////////////////////////////////////////////
scanf("%d",&n);
int i,j,x,y,k;
size=sqrt(n);
blo=(n+size-1)/size;
for(i=1;i<=n;i++) scanf("%d",&a[i]),V[i]=a[i];
sort(V+1,V+n+1);
ln=unique(V+1,V+n+1)-V-1;
for(i=1;i<=n;i++) a[i]=lower_bound(V+1,V+ln+1,a[i])-V;
for(i=1;i<=n;i++) {
update(1,ln,a[i],root[i],root[i-1]);
}
for(i=1;i<=blo;i++) {
L[i]=R[i-1]+1; R[i]=min(i*size,n);
for(j=L[i];j<=R[i];j++) {
pos[j]=i;
}
}
for(i=1;i<=blo;i++) {
memset(s,0,sizeof(s));
for(j=L[i];j<=n;j++) {
ansblo[i][j]=ansblo[i][j-1]+j-L[i]-find(a[j]);
fix(a[j]);
}
}
scanf("%d",&m);
ll ans=0;
while(m--) {
scanf("%d%d",&x,&y);
x^=ans; y^=ans;
ans=work(x,y);
printf("%d\n",ans);
}
}

BZOJ_3744_Gty的妹子序列的更多相关文章

  1. BZOJ 3809: Gty的二逼妹子序列

    3809: Gty的二逼妹子序列 Time Limit: 80 Sec  Memory Limit: 28 MBSubmit: 1387  Solved: 400[Submit][Status][Di ...

  2. 【BZOJ-3809】Gty的二逼妹子序列 分块 + 莫队算法

    3809: Gty的二逼妹子序列 Time Limit: 80 Sec  Memory Limit: 28 MBSubmit: 1072  Solved: 292[Submit][Status][Di ...

  3. BZOJ3809: Gty的二逼妹子序列

    Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题.   对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数.   为了方 ...

  4. bzoj 3744: Gty的妹子序列 主席树+分块

    3744: Gty的妹子序列 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 101  Solved: 34[Submit][Status] Descr ...

  5. Bzoj 3809: Gty的二逼妹子序列 莫队,分块

    3809: Gty的二逼妹子序列 Time Limit: 35 Sec  Memory Limit: 28 MBSubmit: 868  Solved: 234[Submit][Status][Dis ...

  6. BZOJ 3744 Gty的妹子序列

    Description 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见-- 某天,蒟蒻Autumn发现了从 Gty的妹子树上掉落下来了许多妹子,他发现 她们排成了一个序 ...

  7. 【bzoj3809】Gty的二逼妹子序列

    Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数. 为了方便,我们 ...

  8. BZOJ_3809_Gty的二逼妹子序列 && BZOJ_3236_[Ahoi2013]作业 _莫队+分块

    BZOJ_3809_Gty的二逼妹子序列 && BZOJ_3236_[Ahoi2013]作业 _莫队+分块 Description Autumn和Bakser又在研究Gty的妹子序列了 ...

  9. BZOJ 3744 Gty的妹子序列 (分块 + BIT)

    3744: Gty的妹子序列 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1931  Solved: 570[Submit][Status][Dis ...

随机推荐

  1. LVS + KEEPALIVED + WINDOWS SERVER 2008 R2 ------高可用负载均衡(转)

    工作原理此处不作讲解,自己去官方网站学习(http://www.linuxvirtualserver.org),这里重点讲如何配置!注:最好从官方网站对其进行了解,不至于会对某些问题产生误解,尽管是英 ...

  2. 开源项目WebImageView载入图片

    项目地址:https://github.com/ZaBlanc/WebImageView 作者对载入图片,以及图片的内存缓存和磁盘缓存做了封装. 代码量不多.可是可以满足一般的载入图片. 先看下项目结 ...

  3. Selenium3 Python3 Web自动化测试从基础到项目实战之二浏览器的不同设置

    在前面一个章节我们知道了如何通过webdriver去初始化我们得driver,然后我们只需要通过driver就能够去做我们得自动化,首先我们知道我们需要知道得是当我们有driver之后,我们剩下得就是 ...

  4. 在linux系统中I/O 调度的选择 (转)

    I/O 调度算法再各个进程竞争磁盘I/O的时候担当了裁判的角色.他要求请求的次序和时机做最优化的处理,以求得尽可能最好的整体I/O性能. 在linux下面列出4种调度算法 CFQ (Completel ...

  5. 巧用redis位图存储亿级数据与访问

    业务背景 现有一个业务需求,需要从一批很大的用户活跃数据(2亿+)中判断用户是否是活跃用户.由于此数据是基于用户的各种行为日志清洗才能得到,数据部门不能提供实时接口,只能提供包含用户及是否活跃的指定格 ...

  6. 迁移,移动.vagrant.d目录

    默认在 C:\Users\***\.vagrant.d 然后下面有boxes目录 想迁移到其它目录 setx VAGRANT_HOME "/d/.vagrant.d/" setx ...

  7. WPF中的ListBox实现按块显示元素的方法

    本文实例讲述了WPF中的ListBox实现按块显示元素的方法.分享给大家供大家参考,具体如下: 注意:需要设置ListBox的属性 ScrollViewer.HorizontalScrollBarVi ...

  8. [转]Struts form传值

    Struts form传值 大约三四个月没用过struts框架,突然想拾起来,却发现好多都忘了.出现传值传不过来的问题.没办法,上网查了一下,看见了一位老师的帖子,总结的很好.特此转载与分享,文末附链 ...

  9. sql中decode()重要函数使用

    decode()函数简介: 主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明): 使用方法: Select decode(columnname,值1,翻译值1,值2,翻译值2,.. ...

  10. 九度OJ 1028:继续畅通工程 (最小生成树)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3140 解决:1338 题目描述:     省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有 ...