【loj2639】[Tjoi2017]不勤劳的图书管理员
#2639. 「TJOI2017」不勤劳的图书管理员
题目描述
加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员。
他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度。
现在有 nnn 本被打乱顺序的书,在接下来 mmm 天中每天都会因为读者的阅览导致书籍顺序改变位置。因为小豆被要求在接下来的 mmm 天中至少要整理一次图书。
小豆想知道,如果他前 iii 天不去整理,第 iii 天他的厌烦度是多少,这样他好选择厌烦度最小的那天去整理。
输入格式
第一行有两个数 n,mn, mn,m,表示有 nnn 本书和 mmm 天。
接下来 nnn 行,每行两个数,aia_iai 和 viv_ivi,表示第 iii 本书本来应该放在 aia_iai 的位置,这本书有 viv_ivi 页,保证不会有放置同一个位置的书。
接下来 mmm 行,每行两个数,xjx_jxj 和 yjy_jyj,表示在第 jjj 天的第 xjx_jxj 本书会和第 yjy_jyj 本书会因为读者阅读交换位置。
保证 1≤ai,xj,yj≤n1 \leq a_i, x_j, y_j \leq n1≤ai,xj,yj≤n。
输出格式
一共 mmm 行,每行一个数,第 iii 行表示前 iii 天不去整理,第 iii 天小豆的厌烦度。因为这个数可能很大,所以将结果模 109+710 ^ 9 + 7109+7 后输出。
样例
样例输入
5 5
1 1
2 2
3 3
4 4
5 5
1 5
1 5
2 4
5 3
1 3
样例输出
42
0
18
28
48
数据范围与提示
对于 20%20\%20% 的数据,保证 1≤n,m≤50001 \leq n, m \leq 50001≤n,m≤5000。
对于 100%100\%100% 的数据,保证 1≤n,m≤50000,0≤vi≤1051 \leq n, m \leq 50000, 0 \leq v_i \leq 10^51≤n,m≤50000,0≤vi≤105。
题意:每本书有次序和放的位置与权值,两本位置错乱的数会对答案贡献vi+vj , 每次交换两本书的位置,问每次操作之后的权值和;
题解:
将位置也看成次序的权值的话,其实就是维护动态的逆序对,只不过是两对的v都要贡献答案,维护的时候记录v的和 和 个数,交换l,r对[1,l-1]和[r+1,n]没有影响,对于l和r直接判断,l的变化值为减去[l+1,r-1]里面比v[l]小的再加上比v[l]大的,r同理,树状数组套主席树;
直接分块+树状数组的话会好写很多:https://www.cnblogs.com/CQzhangyu/p/7128300.html
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
#include<cmath>
#include<vector>
#include<stack>
#include<map>
#define Run(i,l,r) for(int i=l;i<=r;i++)
#define Don(i,l,r) for(int i=l;i>=r;i--)
#define ll long long
#define inf 0x3f3f3f3f
using namespace std;
const int N=,mod=1e9+;
int n,m,p[N],w[N],ls[N*],rs[N*],rt[N],Rt[N],p1[N],p2[N],sz,cnt[N*],sum[N*];
char gc(){
static char*P1,*P2,s[];
if(P1==P2)P2=(P1=s)+fread(s,,,stdin);
return(P1==P2)?EOF:*P1++;
}//
int rd(){
int x=,f=;char c=gc();
while(c<''||c>''){if(c=='-')f=-;c=gc();}
while(c>=''&&c<=''){x=x*+c-'',c=gc();}
return x*f;
}//
void ins(int&k,int last,int l,int r,int x,int v,int f){
sum[k=++sz]=(sum[last]+v)%mod;
cnt[k]=cnt[last]+f;
ls[k]=ls[last],rs[k]=rs[last];
if(l==r)return;
int mid=(l+r)>>;
if(x<=mid)ins(ls[k],ls[last],l,mid,x,v,f);
else ins(rs[k],rs[last],mid+,r,x,v,f);
}///
int query(int k,int l,int r,int x,int y,int z){
if(x>y)return ;
if(l==x&&r==y)return (sum[k]+1ll*w[z]*cnt[k]%mod)%mod;
else{
int mid=(l+r)>>;
if(y<=mid)return query(ls[k],l,mid,x,y,z);
else if(x>mid)return query(rs[k],mid+,r,x,y,z);
else return (query(ls[k],l,mid,x,mid,z) + query(rs[k],mid+,r,mid+,y,z))%mod;
}
}///
int read(int x,int l,int r,int z){
int ret = ;
for(int i=x;i;i-=i&-i){
ret = (ret + query(Rt[i],,n,l,r,z)) %mod;
}
return ret;
}///
void add(int x,int y,int v,int f){
for(int i=x;i<=n;i+=i&-i){
ins(Rt[i],Rt[i],,n,y,v,f);
}
}///
int Query(int k,int last,int l,int r,int x,int y,int z){
if(x>y)return ;
if(l==x&&r==y)return (sum[k]-sum[last]+1ll*w[z]*(cnt[k]-cnt[last])%mod)%mod;
else{
int mid=(l+r)>>;
if(y<=mid)return Query(ls[k],ls[last],l,mid,x,y,z);
else if(x>mid)return Query(rs[k],rs[last],mid+,r,x,y,z);
else return (Query(ls[k],ls[last],l,mid,x,mid,z) + Query(rs[k],rs[last],mid+,r,mid+,y,z))%mod;
}
}///
int main(){
// freopen("loj1248.in","r",stdin);
// freopen("loj1248.out","w",stdout);
n=rd(),m=rd();
Run(i,,n)p[i]=rd(),w[i]=rd();
ll ans = ;
for(int i=;i<=n;i++){
ans=(ans+query(rt[i-],,n,p[i]+,n,i))%mod;
ins(rt[i],rt[i-],,n,p[i],w[i],);
}
for(int i=,x,y;i<=m;i++){
x=rd();y=rd();
if(x>y)swap(x,y);
if(x==y){printf("%lld\n",ans);continue;}
if(p[x]>p[y])ans=(ans-w[x]-w[y])%mod;else ans=(ans+w[x]+w[y])%mod;
ans -= (ll)Query(rt[y-],rt[x],,n,,p[x]-,x) + read(y-,,p[x]-,x) - read(x,,p[x]-,x);ans%=mod;
ans += (ll)Query(rt[y-],rt[x],,n,p[x]+,n,x) + read(y-,p[x]+,n,x) - read(x,p[x]+,n,x);ans%=mod;
ans -= (ll)Query(rt[y-],rt[x],,n,p[y]+,n,y) + read(y-,p[y]+,n,y) - read(x,p[y]+,n,y);ans%=mod;
ans += (ll)Query(rt[y-],rt[x],,n,,p[y]-,y) + read(y-,,p[y]-,y) - read(x,,p[y]-,y);ans%=mod;
ans = (ans%mod+mod)%mod;
printf("%lld\n",ans);
add(x,p[x],-w[x],-);add(y,p[y],-w[y],-);
swap(p[x],p[y]);swap(w[x],w[y]);
add(x,p[x],w[x],);add(y,p[y],w[y],);
}//
return ;
}//by tkys_Austin;
【loj2639】[Tjoi2017]不勤劳的图书管理员的更多相关文章
- 【bzoj4889】: [Tjoi2017]不勤劳的图书管理员 分块-BIT
[bzoj4889]: [Tjoi2017]不勤劳的图书管理员 题目大意:给定一个序列(n<=50000),每个数有一个编码ai(ai<=50000)和权值vi(vi<=100000 ...
- 【BZOJ4889】[Tjoi2017]不勤劳的图书管理员 分块+树状数组
[BZOJ4889][Tjoi2017]不勤劳的图书管理员 题目描述 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让 ...
- 洛谷P3759 - [TJOI2017]不勤劳的图书管理员
Portal Description 给出一个\(1..n(n\leq5\times10^4)\)的排列\(\{a_n\}\)和数列\(\{w_n\}(w_i\leq10^5)\),进行\(m(m\l ...
- [P3759][TJOI2017]不勤劳的图书管理员(分块+树状数组)
题目描述 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生 这两本书页数的和的厌烦度.现在有n本被打乱顺序的书 ...
- BZOJ4889 & 洛谷3759:[TJOI2017]不勤劳的图书管理员——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4889 https://www.luogu.org/problemnew/show/P3759 加里 ...
- [bzoj4889] [Tjoi2017]不勤劳的图书管理员
Description 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度.现在有n本被 ...
- 【bzoj4889】[Tjoi2017]不勤劳的图书管理员 树状数组+分块+二分
题目描述(转自洛谷) 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度.现在有n本被打 ...
- [TJOI2017] 不勤劳的图书管理员
题目描述 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让小豆产生这两本书页数的和的厌烦度.现在有n本被打乱顺序的书, ...
- 4889: [Tjoi2017]不勤劳的图书管理员 树套树
国际惯例的题面(Bzoj没有,洛谷找的):动态加权逆序对,一眼树套树.256MB内存,5e4范围,不虚不虚.首先把交换改成两个插入和两个删除.考虑插入和删除的贡献,就是统计前面比这个值大的数的数值和, ...
随机推荐
- HttpServletResponse 之 sendError( )
直接返回http 401状态,提示重新登录 response.sendError(401, "当前账户未登录或会话失效,请重新登录!) HTTP状态码列表: 100Continue继续.客户 ...
- HPUX 配置zabbix开机自动启动
1. 在/etc/rc.config.d目录下创建zabbixd文件,并增加以下内容: #!/sbin/sh # v1.0 ?zabbixd startup/kill config ...
- 微信小程序-----自定义验证码实现
这一段时间做小程序项目,使用的是mpvue的框架,需要自己实现验证码输入,模拟input的光标,上一个框输入后后一个框自动获取焦点,删除时从后往前依次删除.下图是整体效果: <template& ...
- gulp4.0 存在的错误信息 The following tasks did not complete: default,Did you forget to signal async completion?
当gulp为如下代码的时候: // 以下代码会执行在node环境下 const gulp = require( "gulp" ); // 创建一个gulp的任务 gulp.task ...
- FPGA的过去,现在和未来
我们知道,相对于专业的ASIC,FPGA有上市时间和成本上的优势.另外,在大多数情况下,FPGA执行某些功能较之CPU上的软件操作更高效.这就是为什么我们认为它不但会运用在数据中心的服务器.交换器.存 ...
- 吴恩达机器学习笔记——正规方程(Normal Equation)
问题描述:m examples : (x(1),y(1)), (x(2),y(2)),..., (x(m),y(m)) and n features; 计算方法:θ = (XTX)-1XTy; 计算过 ...
- dRMT: Disaggregated Programmable Switching
dRMT: Disaggregated Programmable Switching 2017年SIGCOMM会议上提出的新型可编程交换机架构,对2013年提出的RMT架构存在的问题进行了优化. 主要 ...
- iOS-UICollectionViewController协议及回调
一.UICollectionViewDataSource 1.返回Section数量的方法 - (NSInteger)numberOfSectionsInCollectionView: (UIColl ...
- 树莓派两用优盘制作(FAT32存储+EXT树莓派系统)
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:树莓派两用优盘制作(FAT32存储+EXT树莓派系统) 本文地址:http://tec ...
- Spring学习 6- Spring MVC (Spring MVC原理及配置详解)
百度的面试官问:Web容器,Servlet容器,SpringMVC容器的区别: 我还写了个文章,说明web容器与servlet容器的联系,参考:servlet单实例多线程模式 这个文章有web容器与s ...