根据Hall定理,若存在一个区间满足内部需求数$>$内部石子数,则不存在完美匹配。

由于区间互不包含,所以设:

$a[i]$表示右端点$\leq i$的区间的容量之和。

$b[i]$表示左端点$\leq i$的区间的容量之和。

$s[i]$表示前$i$个位置的石子数之和。

则区间$[l,r]$的:

石子数$=s[r]-s[l-1]$。

需求数$=a[r]-b[l-1]$。

即对于任意$0\leq i<j\leq n$,要满足:

$\min((s[j]-a[j])-(s[i]-b[i]))\geq 0$

$f[i]=s[i]-a[i]$

$g[i]=s[i]-b[i]$

考虑$[l,r]$区间需求数为$k$时对匹配的影响:

$f[r..n]-=k$

$g[l..n]-=k$

那么当$k$取$\min(f[\geq r])-\max(g[<l])$时刚好满足所有限制。

线段树维护即可。

时间复杂度$O(m\log n)$。

#include<cstdio>
#include<algorithm>
using namespace std;
const int N=40010,M=131100,inf=~0U>>1;
int n,m,i,x,y,z,P,a[N],f[M],g[M],tf[M],tg[M];
inline void tagf(int x,int y){f[x]+=y;tf[x]+=y;}
inline void tagg(int x,int y){g[x]+=y;tg[x]+=y;}
inline void pb(int x){
if(tf[x])tagf(x<<1,tf[x]),tagf(x<<1|1,tf[x]),tf[x]=0;
if(tg[x])tagg(x<<1,tg[x]),tagg(x<<1|1,tg[x]),tg[x]=0;
}
inline void up(int x){
f[x]=min(f[x<<1],f[x<<1|1]);
g[x]=max(g[x<<1],g[x<<1|1]);
}
void build(int x,int a,int b){
if(a==b){f[x]=g[x]=::a[a];return;}
int mid=(a+b)>>1;
build(x<<1,a,mid),build(x<<1|1,mid+1,b);
up(x);
}
void changef(int x,int a,int b,int c,int d,int p){
if(c<=a&&b<=d){tagf(x,-p);return;}
pb(x);
int mid=(a+b)>>1;
if(c<=mid)changef(x<<1,a,mid,c,d,p);
if(d>mid)changef(x<<1|1,mid+1,b,c,d,p);
up(x);
}
void changeg(int x,int a,int b,int c,int d,int p){
if(c<=a&&b<=d){tagg(x,-p);return;}
pb(x);
int mid=(a+b)>>1;
if(c<=mid)changeg(x<<1,a,mid,c,d,p);
if(d>mid)changeg(x<<1|1,mid+1,b,c,d,p);
up(x);
}
int askf(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return f[x];
pb(x);
int mid=(a+b)>>1,t=inf;
if(c<=mid)t=askf(x<<1,a,mid,c,d);
if(d>mid)t=min(t,askf(x<<1|1,mid+1,b,c,d));
return t;
}
int askg(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return g[x];
pb(x);
int mid=(a+b)>>1,t=-inf;
if(c<=mid)t=askg(x<<1,a,mid,c,d);
if(d>mid)t=max(t,askg(x<<1|1,mid+1,b,c,d));
return t;
}
int main(){
scanf("%d%d%d%d%d",&n,&x,&y,&z,&P);
for(i=1;i<=n;i++)a[i]=(1LL*(i-x)*(i-x)+1LL*(i-y)*(i-y)+1LL*(i-z)*(i-z))%P,a[i]+=a[i-1];
build(1,0,n);
scanf("%d%d%d%d%d%d%d",&m,&a[1],&a[2],&x,&y,&z,&P);
for(i=3;i<=m;i++)a[i]=(1LL*x*a[i-1]+1LL*y*a[i-2]+z)%P;
for(i=1;i<=m;i++){
scanf("%d%d",&x,&y);
printf("%d\n",z=min(askf(1,0,n,y,n)-askg(1,0,n,0,x-1),a[i]));
changef(1,0,n,y,n,z);
changeg(1,0,n,x,n,z);
}
return 0;
}

  

BZOJ2138 : stone的更多相关文章

  1. [BZOJ2138]stone(Hall定理,线段树)

    Description 话说Nan在海边等人,预计还要等上M分钟.为了打发时间,他玩起了石子.Nan搬来了N堆石子,编号为1到N,每堆 包含Ai颗石子.每1分钟,Nan会在编号在\([L_i,R_i] ...

  2. [BZOJ2138]stone[霍尔定理+线段树]

    题意 一共有 \(n\) 堆石子,每堆石子有一个数量 \(a\) ,你要进行 \(m\) 次操作,每次操作你可以在满足前 \(i-1\) 次操作的回答的基础上选择在 \([L_i,R_i]\) 区间中 ...

  3. 【BZOJ2138】stone Hall定理+线段树

    [BZOJ2138]stone Description 话说Nan在海边等人,预计还要等上M分钟.为了打发时间,他玩起了石子.Nan搬来了N堆石子,编号为1到N,每堆包含Ai颗石子.每1分钟,Nan会 ...

  4. 【BZOJ2138】stone(线段树,Hall定理)

    [BZOJ2138]stone(线段树,Hall定理) 题面 BZOJ 题解 考虑一个暴力. 我们对于每堆石子和每个询问,显然是匹配的操作. 所以可以把石子拆成\(a_i\)个,询问点拆成\(K_i\ ...

  5. 【BZOJ2138】stone(线段树+hall定理)

    传送门 题意: 现在有\(n\)堆石子,每堆石子有\(a_i\)个. 之后会有\(m\)次,每次选择\([l,r]\)的石子堆中的石子扔\(k\)个,若不足,则尽量扔. 现在输出\(1\)~\(m\) ...

  6. 【BZOJ2138】stone

    题目 好厉害的题啊 这道题不难看成一个二分图模型,但是给人一种求最大匹配的感觉,这实在不是很好求的样子,于是自闭了 但是不妨这样来考虑,对于一个需求\(k_i\),我们求一个最大的\(x\leq k_ ...

  7. POJ1740A New Stone Game[组合游戏]

    A New Stone Game Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 5769   Accepted: 3158 ...

  8. timus 1180. Stone Game 解题报告

    1.题目: 1180. Stone Game Time limit: 1.0 secondMemory limit: 64 MB Two Nikifors play a funny game. The ...

  9. HDU 4048 Zhuge Liang's Stone Sentinel Maze

    Zhuge Liang's Stone Sentinel Maze Time Limit: 10000/4000 MS (Java/Others)    Memory Limit: 32768/327 ...

随机推荐

  1. 论文阅读笔记八:SegNet: A Deep Convolutional Encoder-Decoder Architecture for Image Segmentation (IEEE2017)

    原文链接:https://arxiv.org/pdf/1511.00561.pdf github(tensorflow):https://github.com/aizawan/segnet 基于Seg ...

  2. python爬虫-淘宝商品密码(图文教程附源码)

    今天闲着没事,不想像书上介绍的那样,我相信所有的数据都是有规律可以寻找的,然后去分析了一下淘宝的商品数据的规律和加密方式,用了最简单的知识去解析了需要的数据. 这个也让我学到了,解决问题的方法不止一个 ...

  3. 几种stl的应用

    1.set(特点:插入后元素自动从小到大排序) set< int > ::iterator it;//迭代器,可以指向同类型的集合 q.find(k);//其中一个元素k的地址 q.cou ...

  4. mysql查看工具——mysql profiler sql

    http://www.profilesql.com/download/ 开发同学的福利--mysql监控工具sqlprofiler,类似sqlserver的profiler工具 https://www ...

  5. expdp、impdp 使用sys用户操作时的注意事项

    https://blog.csdn.net/ctypyb2002/article/details/78420711

  6. C#版本与Framework的关系

    C# 1.0 released with .NET 1.0 and VS2002 (January 2002) C# 1.2 (bizarrely enough); released with .NE ...

  7. 【BZOJ4155】[Ipsc2015]Humble Captains

    题解: 第一问裸的最小割 第二问考虑贪心 我们把边权平均分配给两个点 然后就变成了给n个数分两组差最小 np-hard问题 暴力背包,操作存在区间左移,右移,or bieset优化

  8. Nginx配置多个基于域名的虚拟主机+实验环境搭建+测试

    标签:Linux 域名 Nginx 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://xpleaf.blog.51cto.com/9 ...

  9. flink的集群的HA高可用

    对于一个企业级的应用,稳定性是首要要考虑的问题,然后才是性能,因此 HA 机制是必不可少的: 和 Hadoop 一代一样,从架构中我们可以很明显的发现 JobManager 有明显的单点问题(SPOF ...

  10. Openstack1 云计算与虚拟化概念

    一.云概念 二.虚拟化,云计算不等于虚拟化,但是云计算需要用到虚拟化的技术 1.服务器虚拟化 2.桌面虚拟化 3.应用虚拟化 三.区别 1.虚拟化是具体的技术. 2.云计算是交付使用的一种模式