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

https://www.luogu.org/problemnew/show/P3759

加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员。他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度。现在有n本被打乱顺序的书,在接下来m天中每天都会因为读者的阅览导致书籍顺序改变位置。因为小豆被要求在接下来的m天中至少要整理一次图书。小豆想知道,如果他前i天不去整理,第i天他的厌烦度是多少,这样他好选择厌烦度最小的那天去整理。

最开始以为看的题解很naive,后来发现是自己太naive了。

看起来就像是查逆序对,对于l和r的交换,其贡献的变更只与[l+1,r-1]这些区间有关,可以变成查询这段区间内有多少数满足与l和r构成逆序对。

这个明显可以主席树做。

然而之后你需要交换这两个数……emmm待修改主席树呗。

其实就是树状数组套一个动态开点线段树(因为本质都差不多就都叫成主席树好了。)

剩下的就是码码码了。

(注意取模对常数的影响。)

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=5e4+;
const int p=1e9+;
inline int read(){
int X=,w=;char ch=;
while(ch<''||ch>''){w|=ch=='-';ch=getchar();}
while(ch>=''&&ch<='')X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
struct tree{
int l,r;
ll v,c;
}tr[N*];
int rt[N],pool,n,m;
ll ans,a[N],v[N],b[N],cnt[N];
inline int lowbit(int x){return x&(-x);}
inline void add(int x,int y){
for(int i=x;i<=n;i+=lowbit(i))b[i]+=y,cnt[i]++;
}
inline ll qry_val(int x){
ll res=;
for(int i=x;i;i-=lowbit(i))res+=b[i];
return res;
}
inline ll qry_cnt(int x){
ll res=;
for(int i=x;i;i-=lowbit(i))res+=cnt[i];
return res;
}
inline void insert(int &x,int l,int r,int pos,int v,int w){
if(!x)x=++pool;
tr[x].v+=v;tr[x].c+=w;
if(l==r)return;
int mid=(l+r)>>;
if(pos<=mid)insert(tr[x].l,l,mid,pos,v,w);
else insert(tr[x].r,mid+,r,pos,v,w);
}
inline void ins(int i,int x,int y,int w){
for(;i<=n;i+=lowbit(i))insert(rt[i],,n,x,y,w);
}
inline ll sqv(int x,int l,int r,int l1,int r1){
if(r<l1||r1<l)return ;
if(l1<=l&&r<=r1)return tr[x].v;
int mid=(l+r)>>;
return sqv(tr[x].l,l,mid,l1,r1)+sqv(tr[x].r,mid+,r,l1,r1);
}
inline ll sqc(int x,int l,int r,int l1,int r1){
if(r<l1||r1<l)return ;
if(l1<=l&&r<=r1)return tr[x].c;
int mid=(l+r)>>;
return sqc(tr[x].l,l,mid,l1,r1)+sqc(tr[x].r,mid+,r,l1,r1);
}
inline ll query_val(int l,int r,int l1,int r1){
if(l>r||l1>r1)return ;
l--;ll res=;
for(int i=r;i;i-=lowbit(i))res=(res+sqv(rt[i],,n,l1,r1))%p;
for(int i=l;i;i-=lowbit(i))res=(res-sqv(rt[i],,n,l1,r1))%p;
return (res+p)%p;
}
inline ll query_cnt(int l,int r,int l1,int r1){
if(l>r||l1>r1)return ;
l--;ll res=;
for(int i=r;i;i-=lowbit(i))res=(res+sqc(rt[i],,n,l1,r1))%p;
for(int i=l;i;i-=lowbit(i))res=(res-sqc(rt[i],,n,l1,r1))%p;
return (res+p)%p;
}
inline void check(ll &x){
while(x>=p)x-=p;
while(x<)x+=p;
}
int main(){
n=read(),m=read();
for(int i=;i<=n;i++){
a[i]=read(),v[i]=read();
ins(i,a[i],v[i],);
}
for(int i=n;i>=;i--){
add(a[i],v[i]);
ans=(ans+qry_val(a[i]-)+qry_cnt(a[i]-)*v[i])%p;
}
for(int i=;i<=m;i++){
int l=read(),r=read();
if(l==r){printf("%lld\n",ans);continue;}
if(l>r)swap(l,r);
ans=ans+query_val(l+,r-,,a[r]-);check(ans);
ans=ans+query_cnt(l+,r-,,a[r]-)*v[r];check(ans);
ans=ans-query_val(l+,r-,a[r]+,n);check(ans);
ans=ans-query_cnt(l+,r-,a[r]+,n)*v[r];check(ans);
ans=ans+query_val(l+,r-,a[l]+,n);check(ans);
ans=ans+query_cnt(l+,r-,a[l]+,n)*v[l];check(ans);
ans=ans-query_val(l+,r-,,a[l]-);check(ans);
ans=ans-query_cnt(l+,r-,,a[l]-)*v[l];check(ans);
if(a[l]>a[r])ans-=v[l]+v[r];
else ans+=v[l]+v[r];
check(ans);
ins(l,a[l],-v[l],-);ins(r,a[r],-v[r],-);
swap(a[l],a[r]);swap(v[l],v[r]);
ins(l,a[l],v[l],);ins(r,a[r],v[r],);
printf("%lld\n",ans);
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/ +

+++++++++++++++++++++++++++++++++++++++++++

BZOJ4889 & 洛谷3759:[TJOI2017]不勤劳的图书管理员——题解的更多相关文章

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

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

  2. 洛谷P3759 [TJOI2017]不勤劳的图书管理员 【树状数组套主席树】

    题目链接 洛谷P3759 题解 树状数组套主席树板题 #include<algorithm> #include<iostream> #include<cstring> ...

  3. Luogu 3759 [TJOI2017]不勤劳的图书管理员

    再也不作死写FhqTreap作内层树了,卡的不如暴力呜呜呜…… 题意翻译:给一个序列,每个下标包含两个属性$a$和$v$,求第一个属性与下标形成的所有逆序对的第二个属性和,给出$m$个交换两个下标的操 ...

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

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

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

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

  6. 【loj2639】[Tjoi2017]不勤劳的图书管理员

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

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

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

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

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

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

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

随机推荐

  1. hdu2199Can you solve this equation?(解方程+二分)

    Can you solve this equation? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K ( ...

  2. 关于自学C语言开始时应该注意的问题分享—未完待续......

    ---恢复内容开始--- 自学C语言编程总结 第1章C语言概述 1.     如果用户将主函数的返回值类型定义为了void,则不需要返回任何值: 2.     C语言的基本结构包括主函数和程序体两部分 ...

  3. Unity 特殊目录

    其他目录 Application.persistentDataPath:webGL平台只能使用这个

  4. array.some() 方法兼容ie8

    在第 5 版时,some 被添加进 ECMA-262 标准:这样导致某些实现环境可能不支持它.你可以把下面的代码插入到脚本的开头来解决此问题,从而允许在那些没有原生支持它的实现环境中使用它.该算法是  ...

  5. “Hello World!”团队第三周召开的第一次会议

    今天是我们团队“Hello World!”团队第三周召开的第一次会议.博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.Todo List 六.会议照片 七.燃尽图 一.会议时间 ...

  6. 20145214 《Java程序设计》第10周学习总结

    20145214 <Java程序设计>第10周学习总结 学习内容总结 计算机网络概述 在计算机网络中,现在命名IP地址的规定是IPv4协议,该协议规定每个IP地址由4个0-255之间的数字 ...

  7. 内存转储文件调试系统崩溃bug

    百度百科:内存转储文件 内存转储是用于系统崩溃时,将内存中的数据转储保存在转储文件中,供给有关人员进行排错分析用途.而它所保存生成的文件就叫做内存转储文件. 内存转储文件也被称作虚拟内存,它是用硬盘里 ...

  8. SQLite - Python

    SQLite - Python 安装 SQLite3 可使用 sqlite3 模块与 Python 进行集成.sqlite3 模块是由 Gerhard Haring 编写的.它提供了一个与 PEP 2 ...

  9. 转 PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)

    PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)   通过curl_setopt()函数可以方便快捷的抓取网页(采集很方便),curl_setopt 是php的一个 ...

  10. C# 知识回顾 - 你真的懂异常(Exception)吗?

    你真的懂异常(Exception)吗? 目录 异常介绍 异常的特点 怎样使用异常 处理异常的 try-catch-finally 捕获异常的 Catch 块 释放资源的 Finally 块 一.异常介 ...