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

题面

BZOJ

题解

考虑一个暴力。

我们对于每堆石子和每个询问,显然是匹配的操作。

所以可以把石子拆成\(a_i\)个,询问点拆成\(K_i\)个,这样就是每次进行一次二分图的匹配。

当然可以用网络流+线段树优化连边来做,但是这样复杂度太高。

还是回到二分图的匹配问题,我们现在要验证的就是是否存在对于当前询问点的完美匹配。

关于完美匹配,有\(Hall\)定理,如果存在完美匹配,假设左侧的点有\(|X|\)个,那么这些点连向右边的点的点集的并\(Y\),满足\(|X|\le |Y|\)

因为询问点拆开后,每个点的连向右边的点集都是一样的,所以相当于就是\(K_i\le|Y|\)

只提取出所有有用的石子,按顺序编号。设\(s_i\)表示前\(i\)堆石子的个数和。

如果存在完美匹配,那么在任意时刻,所有存在于区间\([L,R]\)之内的询问的石子个数的总和\(T[L,R]\)一定小于区间\([L,R]\)之内的石子的总和。

也就是\(s_R-s_{L-1}\ge T[L,R]\),发现题目中的性质,任何询问不存在包含关系。

那么我们假设\(TL_i\)表示左端点在\([1,i]\)中的询问的总和,\(TR_i\)表示右端点在\([1,i]\)中的询问的总和。

那么因为\(T[L,R]=TR_R-TL_{L-1}\),所以我们也可以很容易的表示出\(T\)来。

所以,现在的不等式表达为\(s[R]-s[L-1]\ge TR[R]-TL[L-1]\)

所以\(s[R]-TR[R]\ge s[L-1]-TL[L-1]\)

设\(f[i]=s[i]-TR[i],g[i]=s[i]-TL[i]\),所以是\(f[R]\ge g[L-1]\)

我们发现,如果从\([L,R]\)区间中拿走若干石头,在不等式中变化的只有\(TR[R]\)

也就是只有\(f[i]\)会减小。所以我们能够拿走的数量为\(min(K[i],f[R]-g[L-1])\)

对于当前询问区间\([L,R]\),会对于所有的\(x\in [1,L],y\in [R,n],[x,y]\)产生影响

也就是任何包含当前区间的区间也需要满足\(Hall\)定理,在本题中也就是\(f[y]\ge g[x]\)

那么当前步的答案就是所有的\(min(K[i],f[y]-g[x])\),那么取后缀\(f\)最小值,前缀\(g\)最大值即可。

每次拿线段树区间更新一下即可。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
#define ll long long
#define RG register
#define MAX 40040
#define lson (now<<1)
#define rson (now<<1|1)
inline int read()
{
RG int x=0,t=1;RG char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
int n,m,a[MAX],K[MAX],s[MAX];
struct SegMentTree_Max
{
int t[MAX<<2],tag[MAX<<2];
void puttag(int now,int w){t[now]+=w;tag[now]+=w;}
void pushdown(int now,int l,int r){puttag(lson,tag[now]);puttag(rson,tag[now]);tag[now]=0;}
void Build(int now,int l,int r)
{
if(l==r){t[now]=s[l];return;}
int mid=(l+r)>>1;
Build(lson,l,mid);Build(rson,mid+1,r);
t[now]=max(t[lson],t[rson]);
}
void Modify(int now,int l,int r,int L,int R,int w)
{
if(L<=l&&r<=R){puttag(now,w);return;}
int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R,w);
if(R>mid)Modify(rson,mid+1,r,L,R,w);
t[now]=max(t[lson],t[rson]);
}
int Query(int now,int l,int r,int L,int R)
{
if(L>R)return 0;if(L<=l&&r<=R)return t[now];
int mid=(l+r)>>1,ret=0;pushdown(now,l,r);
if(L<=mid)ret=max(ret,Query(lson,l,mid,L,R));
if(R>mid)ret=max(ret,Query(rson,mid+1,r,L,R));
return ret;
}
}G;
struct SegMentTree_Min
{
int t[MAX<<2],tag[MAX<<2];
void puttag(int now,int w){t[now]+=w;tag[now]+=w;}
void pushdown(int now,int l,int r){puttag(lson,tag[now]);puttag(rson,tag[now]);tag[now]=0;}
void Build(int now,int l,int r)
{
if(l==r){t[now]=s[l];return;}
int mid=(l+r)>>1;
Build(lson,l,mid);Build(rson,mid+1,r);
t[now]=min(t[lson],t[rson]);
}
void Modify(int now,int l,int r,int L,int R,int w)
{
if(L<=l&&r<=R){puttag(now,w);return;}
int mid=(l+r)>>1;pushdown(now,l,r);
if(L<=mid)Modify(lson,l,mid,L,R,w);
if(R>mid)Modify(rson,mid+1,r,L,R,w);
t[now]=min(t[lson],t[rson]);
}
int Query(int now,int l,int r,int L,int R)
{
if(L>R)return 0;if(L<=l&&r<=R)return t[now];
int mid=(l+r)>>1,ret=1e9;pushdown(now,l,r);
if(L<=mid)ret=min(ret,Query(lson,l,mid,L,R));
if(R>mid)ret=min(ret,Query(rson,mid+1,r,L,R));
return ret;
}
}F;
int main()
{
freopen("stone.in","r",stdin);
freopen("stone.out","w",stdout);
n=read();int X=read(),Y=read(),Z=read(),P=read();
for(int i=1;i<=n;++i)s[i]=a[i]=(1ll*(i-X)*(i-X)%P+1ll*(i-Y)*(i-Y)%P+1ll*(i-Z)*(i-Z)%P)%P;
for(int i=1;i<=n;++i)s[i]+=s[i-1];
m=read();K[1]=read(),K[2]=read(),X=read(),Y=read(),Z=read(),P=read();
for(int i=3;i<=m;++i)K[i]=(1ll*K[i-1]*X%P+1ll*K[i-2]*Y%P+Z)%P;
if(!m)return 0;G.Build(1,1,n);F.Build(1,1,n);
for(int i=1;i<=m;++i)
{
int l=read(),r=read();
K[i]=min(K[i],F.Query(1,1,n,r,n)-G.Query(1,1,n,1,l-1));
F.Modify(1,1,n,r,n,-K[i]);G.Modify(1,1,n,l,n,-K[i]);
printf("%d\n",K[i]);
}
return 0;
}

【BZOJ2138】stone(线段树,Hall定理)的更多相关文章

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

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

  2. BZOJ1135:[POI2009]Lyz(线段树,Hall定理)

    Description 初始时滑冰俱乐部有1到n号的溜冰鞋各k双.已知x号脚的人可以穿x到x+d的溜冰鞋. 有m次操作,每次包含两个数ri,xi代表来了xi个ri号脚的人.xi为负,则代表走了这么多人 ...

  3. bzoj 1135 [POI2009]Lyz 线段树+hall定理

    1135: [POI2009]Lyz Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 573  Solved: 280[Submit][Status][ ...

  4. BZOJ 1135 P3488 LYZ-Ice Skates 线段树+Hall

    https://www.luogu.org/problem/P3488 根据Hall定理 左边任意一个区间L-R a[i]的和sum[l~r] 都要<= (R-L+1+d)*K 把(R-L+1) ...

  5. 【题解】 bzoj1135: [POI2009]Lyz (线段树+霍尔定理)

    题面戳我 Solution 二分图是显然的,用二分图匹配显然在这个范围会炸的很惨,我们考虑用霍尔定理. 我们任意选取穿\(l,r\)的号码鞋子的人,那么这些人可以穿的鞋子的范围是\(l,r+d\),这 ...

  6. 【题解】 bzoj3693: 圆桌会议 (线段树+霍尔定理)

    bzoj3693 Solution: 显然我们可以把人和位置抽象成点,就成了一个二分图,然后就可以用霍尔定理判断是否能有解 一开始我随便YY了一个\(check\)的方法:就是每次向后一组,我们就把那 ...

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

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

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

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

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

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

随机推荐

  1. 洛谷 P1941 飞扬的小鸟

    洛谷 P1941 飞扬的小鸟 原题链接 首先吐槽几句 noip都快到了,我还不刷起联赛大水题! 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节 ...

  2. 洛谷P2464 [SDOJ2008]郁闷的小J

    洛谷P2464 [SDOJ2008]郁闷的小J 题目描述 小J是国家图书馆的一位图书管理员,他的工作是管理一个巨大的书架.虽然他很能吃苦耐劳,但是由于这个书架十分巨大,所以他的工作效率总是很低,以致他 ...

  3. CentOS 6.5关闭防火墙

    关闭命令:  service iptables stop 永久关闭防火墙:chkconfig iptables off 两个命令同时运行,运行完成后查看防火墙关闭状态 service iptables ...

  4. Python小白学习之如何添加类属性和类方法,修改类私有属性

    如何添加类属性和类方法,修改类私有属性 2018-10-26  11:42:24 类属性.定义类方法.类实例化.属性初始化.self参数.类的私有变量的个人学习笔记 直接上实例: class play ...

  5. 概念这种东西--node.js

    概念是一个既简单又复杂.既招人爱又招人恨的东西.概念是对一事务或现象的抽象.抽象好了,那就太方便问题的解决了,抽象坏了,那就驴唇不对马嘴,反而会让逻辑一塌糊涂.现实中经常有这样的概念:东北人怎么怎么样 ...

  6. 445. Cosine Similarity【LintCode java】

    Description Cosine similarity is a measure of similarity between two vectors of an inner product spa ...

  7. Delphi 实现照片抽奖-原创

    有单位年会要用照片抽奖,上网搜了几个都不满意,且居然还要收费.自己写一个算了.只是有一点不爽,Delphi 7 在 Windows 7 64位下有问题,不能双击 dpr 文件直接打开项目! 关于性能: ...

  8. 查看struts包源码

  9. struts常量<constant>说明

    1.<constant name="struts.action.extension" value="do" />这个时候访问action都必须加.d ...

  10. ncnblogs.com的用户体验

    你是什么样的用户, 有什么样的心理, 对cnblogs 的期望值是什么? 我是一名普通的学生,上cnblogs的期望是发表博客完成老师布置的任务. 当你第一次使用cnblogs 的功能的时候, 碰到了 ...