传送门

据说正解线段树套平衡树

然而网上参考(抄)了一个树状数组套动态开点线段树的

思路比较清楚,看代码应该就明白了

 //minamoto
#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
const int N=,mod=1e9+;
#define getc() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
char buf[<<],*p1=buf,*p2=buf;
inline int read(){
#define num ch-'0'
char ch;bool flag=;int res;
while(!isdigit(ch=getc()))
(ch=='-')&&(flag=true);
for(res=num;isdigit(ch=getc());res=res*+num);
(flag)&&(res=-res);
#undef num
return res;
}
char sr[<<],z[];int C=-,Z;
inline void Ot(){fwrite(sr,,C+,stdout),C=-;}
inline void print(ll x){
if(C><<)Ot();if(x<)sr[++C]=,x=-x;
while(z[++Z]=x%+,x/=);
while(sr[++C]=z[Z],--Z);sr[++C]='\n';
}
int n,m,a[N],b[N],c[N],cntt[N];
ll ans;
inline void add(int x,int y){
for(;x<=n;x+=x&-x) c[x]+=y,++cntt[x];
}
inline ll sum_v(int x){
ll res=;
for(;x;x-=x&-x) res+=c[x];return res;
}
inline ll sum_cnt(int x){
ll res=;
for(;x;x-=x&-x) res+=cntt[x];return res;
}
int tot,rt[N],cnt[N<<],L[N<<],R[N<<];ll v[N<<];
void insert(int &p,int l,int r,int x,int k,int t){
if(!p) p=++tot;v[p]+=k,cnt[p]+=t;
if(l==r) return;int mid=l+r>>;
if(x<=mid) insert(L[p],l,mid,x,k,t);
else insert(R[p],mid+,r,x,k,t);
}
inline void add(int x,int y,int k,int t){
for(;x<=n;x+=x&-x) insert(rt[x],,n,y,k,t);
}
int query_v(int p,int l,int r,int ql,int qr){
if(!p) return ;
if(ql<=l&&qr>=r) return v[p];int mid=l+r>>;
int res=;
if(ql<=mid) res+=query_v(L[p],l,mid,ql,qr);
if(qr>mid) res+=query_v(R[p],mid+,r,ql,qr);
return res;
}
int query_cnt(int p,int l,int r,int ql,int qr){
if(!p) return ;
if(ql<=l&&qr>=r) return cnt[p];int mid=l+r>>;
int res=;
if(ql<=mid) res+=query_cnt(L[p],l,mid,ql,qr);
if(qr>mid) res+=query_cnt(R[p],mid+,r,ql,qr);
return res;
}
ll Q_v(int l,int r,int ql,int qr){
if(l>r||ql>qr) return ;
ll res=;
for(;r;r-=r&-r) res+=query_v(rt[r],,n,ql,qr);
for(--l;l;l-=l&-l) res-=query_v(rt[l],,n,ql,qr);return res;
}
ll Q_cnt(int l,int r,int ql,int qr){
if(l>r||ql>qr) return ;
ll res=;
for(;r;r-=r&-r) res+=query_cnt(rt[r],,n,ql,qr);
for(--l;l;l-=l&-l) res-=query_cnt(rt[l],,n,ql,qr);return res;
}
inline void dec(ll &x,ll y){
while(x<y) x+=mod;x-=y;
}
int main(){
//freopen("testdata.in","r",stdin);
n=read(),m=read();
for(int i=;i<=n;++i) a[i]=read(),b[i]=read();
for(int i=n;i;--i) add(a[i],b[i]),(ans+=sum_v(a[i]-)+sum_cnt(a[i]-)*b[i])%=mod;
for(int i=;i<=n;++i) add(i,a[i],b[i],);
while(m--){
int l=read(),r=read();
if(l>r) swap(l,r);
if(l==r) {print(ans);continue;}
(ans+=Q_v(l+,r-,,a[r]-))%=mod;
(ans+=Q_cnt(l+,r-,,a[r]-)*b[r])%=mod;
dec(ans,Q_v(l+,r-,a[r]+,n));
dec(ans,Q_cnt(l+,r-,a[r]+,n)*b[r]);
(ans+=Q_v(l+,r-,a[l]+,n))%=mod;
(ans+=Q_cnt(l+,r-,a[l]+,n)*b[l])%=mod;
dec(ans,Q_v(l+,r-,,a[l]-));
dec(ans,Q_cnt(l+,r-,,a[l]-)*b[l]);
if(a[l]>a[r]) dec(ans,b[l]+b[r]);
else (ans+=b[l]+b[r])%=mod;
add(l,a[l],-b[l],-),add(l,a[r],b[r],);
add(r,a[r],-b[r],-),add(r,a[l],b[l],);
swap(a[l],a[r]),swap(b[l],b[r]);
print(ans);
}
Ot();
return ;
}

bzoj4889: [Tjoi2017]不勤劳的图书管理员(树套树)的更多相关文章

  1. [TJOI2017]不勤劳的图书管理员(分块+树状数组)

    有一个数组开大会MLE开小会RE的做法:就是树套树,即树状数组套主席树,这种方法比较暴力,然而很遗憾它不能通过,因为其时空复杂度均为O(nlog2n). 想到一种不怎么耗内存,以时间换空间,分块!单次 ...

  2. [bzoj4889] [Tjoi2017]不勤劳的图书管理员

    Description 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度.现在有n本被 ...

  3. 【BZOJ4889】[Tjoi2017]不勤劳的图书管理员 分块+树状数组

    [BZOJ4889][Tjoi2017]不勤劳的图书管理员 题目描述 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让 ...

  4. 【bzoj4889】: [Tjoi2017]不勤劳的图书管理员 分块-BIT

    [bzoj4889]: [Tjoi2017]不勤劳的图书管理员 题目大意:给定一个序列(n<=50000),每个数有一个编码ai(ai<=50000)和权值vi(vi<=100000 ...

  5. 【BZOJ4889】不勤劳的图书管理员(树套树)

    [BZOJ4889]不勤劳的图书管理员(树套树) 题面 又是权限题,烦死了 洛谷真好 题解 分开考虑每一次交换产生的贡献. 假设交换\((x,y)\) 检查\(x\)与\(y\)对于区间\([x+1, ...

  6. 洛谷P3759 - [TJOI2017]不勤劳的图书管理员

    Portal Description 给出一个\(1..n(n\leq5\times10^4)\)的排列\(\{a_n\}\)和数列\(\{w_n\}(w_i\leq10^5)\),进行\(m(m\l ...

  7. 4889: [Tjoi2017]不勤劳的图书管理员 树套树

    国际惯例的题面(Bzoj没有,洛谷找的):动态加权逆序对,一眼树套树.256MB内存,5e4范围,不虚不虚.首先把交换改成两个插入和两个删除.考虑插入和删除的贡献,就是统计前面比这个值大的数的数值和, ...

  8. 【洛谷3759】[TJOI2017] 不勤劳的图书管理员(树套树)

    点此看题面 大致题意: 给定一个序列,每个元素有两个属性\(a_i\)和\(v_i\),每次操作改变两个元素的位置,求每次操作后\(\sum{v_i+v_j}[i<j,a_i>a_j]\) ...

  9. P3759 [TJOI2017]不勤劳的图书管理员 [树套树]

    树套树是什么啊我不知道/dk 我只知道卡常数w // by Isaunoya #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC o ...

随机推荐

  1. long_query_time 设置不生效问题

    由于原来的慢查询日志太大了,有1G多,并且其中包含上一次查询优化前的慢sql,所以想收集最近两天的慢查询语句,故 mysql> show global variables like 'slow% ...

  2. eslint 配合 git (husky)

    为了保证每次提交的 git 代码是正确的,为此我们可以使用 eslint 配合 git hook, 在进行git commit 的时候验证eslint规范 如果 eslint 验证不通过,则不能提交. ...

  3. WebsiteCrawler

    看到网上不少py的爬虫功能极强大,可惜对py了解的不多,以前尝试过使用c# WebHttpRequert类来读取网站的html页面源码,然后通过正则表达式筛选出想要的结果,但现在的网站中,多数使用js ...

  4. 51nod 1537

    题目 神犇题解 证明好巧妙,给跪OTZ 题目的式子:$ {\left( {1{\rm{ + }}\sqrt 2 } \right)^{\rm{n}}} $,设其乘开之后为 $ {\rm{a + b}} ...

  5. 分享知识-快乐自己:论 Mybatis中的关联关系(一对多,多对一,多对多)

    论:一对多:(举例一个省有多个市)就是实体类中有(市)类型集合属性:多对一:(多个市有一个共同的省)就是类中有(省)类型的属性.下面来介绍:一对一.多对一的使用方式. 一对多方: package ml ...

  6. listen 54

    Our library is also open for the local residents. People are doing their Christmas shopping. Later t ...

  7. AndyQsmart ACM学习历程——ZOJ3870 Team Formation(位运算)

    Description For an upcoming programming contest, Edward, the headmaster of Marjar University, is for ...

  8. Elasticsearch搜索引擎版本配置

    简要描述: 搜索引擎版本配置 产品 版本号 ES版本要求 说明 PHP =5.5.38     Java =1.8.0_73   用于支持ES Elasticsearch =2.3.5   搜索引擎 ...

  9. Java关键字以及一些基础解释

    Java Se:Java Me 和Java Ee的基础,允许开发和部署在桌面,服务器,嵌入式环境和实时环境中使用的java程序,支持java web服务开发类 java ee:是目前java技术应用最 ...

  10. ReportEvent的正确使用方式

    向操作系统的事件管理器报告重大信息是一种非常有用的方式,特别是对于没有界面的后台服务而言.如果你对Windows编程有一定了解,应该很快就能想到使用ReportEvent这个API,然后快速写出下面的 ...