Description

传送门

Solution

这题是真的666啊。。。

以下是本题最关键最关键的结论:如果ai<=aj,则在某个时间t,前者的A中沙子克数(记为t(ai))一定大于等于t(aj)。证明显然。

假设我们目前处理到到询问为(t,a),设ri为满足ri<=t的最大值。我们要处理三个量:

1,时刻ri,在不考虑限制(即不考虑沙子数只能为[0,X]范围,它可能比X大,也可能比0小)的情况下,相对于初始时的沙子数变化c。

2,时刻ri,初始A中沙子为0情况下的沙子数down。

3,时刻ri,初始沙子为X情况下的沙子数up。

经过分析,沙子数a加减的过程有4中情况(以下情况的沙子数都是指A中的)。

1:a没有被“沙子数只能为[0,X]范围”这个条件限制过。

2:a只被“沙子数必须<=X”条件限制过。

3:a只被“沙子数必须>=0”条件限制过。

4:a被“沙子数必须>=0”和“沙子数必须<=X”两个条件都限制过。

此处的"限制过"是指在计算到某一步的时候,沙子数量达到极限以至于不会再从上往下掉落。从数学的角度看(以条件沙子数必须>=0为例),即为:a-(r[k]-r[k-1])<0,但由于题目要求,a必须=0。

在最终判断答案的时候,询问(t,a)在时刻ri沙子数的式子为max(down,min(up,a+c))。

证明:

情况1中,由于本题结论并且0<=a<=X,可得a+c<=up,a+c>=down,式子答案为a+c,又因为a没有被限制过,所以该答案正确。

情况2中,假设在时刻t0,a被限制,即t0(a)=X,又因为本题结论,t0(a)<=t0(X),则t0(X)=X。在这一时刻t0(a)=t0(X),正确答案即为up。由于a+c是不受限制(沙子数>=X)的结果,所以a+c>=up。即min(up,a+c)=up,up>=down,式子答案为up,正确。

情况3同理;

情况4由于t(a)=up=down,不论a+c与t(up)的大小关系如何都正确。

求出(ri,a)后,记录一下接下来应该加还是减,直接操作便可得出(t,a)。

所以我们只需要把询问按时间排个序扫一遍就过啦。

Code

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int X,k,r[],Q;
struct node{int t,a,id;
}q[];int ans[];
bool cmp(node x,node y) {return x.t<y.t;}
int pls(int x,int y){return max(,min(X,x+y));}
int main()
{
scanf("%d%d",&X,&k);
for (int i=;i<=k;i++) scanf("%d",&r[i]);
scanf("%d",&Q);
for (int i=;i<=Q;i++)
{
scanf("%d%d",&q[i].t,&q[i].a);q[i].id=i;
}
sort(q+,q+Q+,cmp);
int topr=,topq=,sum=,down=,up=X,add=,js=-;
int cnt;
while (topq<=Q)
{
if (r[topr+]<q[topq].t&&topr<k)
{
topr++;
add=js*(r[topr]-r[topr-]);
down=pls(down,add);up=pls(up,add);
sum+=add;js=-js;
} else
{
cnt=q[topq].t-r[topr];
ans[q[topq].id]=pls(max(down,min(up,q[topq].a+sum)),js*cnt);
topq++;
}
}
for (int i=;i<=Q;i++) printf("%d\n",ans[i]); }

[arc082F]Sandglass的更多相关文章

  1. [arc082f]Sandglass 递推

    Description 有一个沙漏由两个上下相通玻璃球A和B构成,这两个玻璃球都含有一定量的沙子,我们暂且假定AB中位于上方的玻璃球的为U,下方的玻璃球为L,则除非U中没有沙子,否则每秒钟都会有1克沙 ...

  2. [ARC082F] Sandglass(线段树)

    Description 有一个沙漏由两个上下相通玻璃球 \(A\) 和 \(B\) 构成,这两个玻璃球都含有一定量的沙子,我们暂且假定 \(AB\) 中位于上方的玻璃球的为 \(U\),下方的玻璃球为 ...

  3. ARC-082F Sandglass

    题意 有一个含有两个玻璃球的沙漏,分别称这两个玻璃球为\(

  4. NOIp模拟赛二十八

    (这是NOIp模拟赛?应该是NOI模拟赛不小心加了个p) 嗯,假装这是正经的NOIp模拟赛,从今天开始也写写题解吧(这几天被虐的惨惨) 今日情况:8+50+0=58 A题输出样例,B题正解写挂,C题不 ...

  5. AtCoder刷题记录

    构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...

  6. Sandglass

    题目描述 We have a sandglass consisting of two bulbs, bulb A and bulb B. These bulbs contain some amount ...

  7. 【AtCoder】ARC082 F - Sandglass

    [链接]F - Sandglass [题意]给定沙漏A和B,分别装着a和X-a的沙子,开始时A在上B在下,每秒漏1,漏完不再漏.给定n,有n个时刻ai沙漏倒转.给定m个询问,每次询问给定初值a和时刻t ...

  8. 2017国家集训队作业[arc082d]Sandglass

    2017国家集训队作业[arc082d]Sandglass 题意: ​ 有一个沙漏,初始时\(A\)瓶在上方,两个瓶子的最大容量都为\(X\)克,沙子流动的速度为\(1g\)每单位时间.给出\(K\) ...

  9. 【ARC082D】Sandglass

    Description ​ 题目链接 Description ​ 好题.题意是维护一个初始值,交替加减一段时间,有上界\(m\)和下界0(不能超过这两条界限),问对于某一种初始值,在某一个时刻时该值为 ...

随机推荐

  1. IOS 缓存思路

    为了提高程序的响应速度,可以考虑使用缓存(内存缓存\硬盘缓存) 第一次请求数据时内存缓存中没有数据硬盘缓存中没有数据 当服务器返回数据时,需要做以下步骤 使用服务器的数据(比如解析.显示) 将服务器的 ...

  2. 【[SCOI2013]摩托车交易 】

    倍增什么的最慢了,常数太大了 我们可以上树剖啊 但是如果用树剖来查询树上两点之间的最小边权的话,可能只能在上一棵线段树? 那也太\(naive\)了,尽管倍增常数大,但是还是比两个\(log\)快的 ...

  3. Swift 开发语法

    文/Tuberose(简书作者)原文链接:http://www.jianshu.com/p/5e2d4c34f18e著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 简介 Swift 语 ...

  4. 关于Oracle 数据库死锁 转

    转自 https://zhidao.baidu.com/question/200422068111653165.html 一.数据库死锁的现象程序在执行的过程中,点击确定或保存按钮,程序没有响应,也没 ...

  5. SharePoint2013代码操作权限组的几个Demo

    1,清明节闲来无聊,敲代码吧,不知道敲什么,不敲吧,又好像比较颓废,不思进取.遂把以前项目中别的同事负责的权限模块的代码看一看,做俩个Demo. (1)代码创建组 protected void Cre ...

  6. 网页静态化解决方案-Freemarker

    1.1    技术简介与使用 1.1.1     简介 为什么使用: 1.  减轻数据库的访问压力,静态化比较适合大规模且相对变化不太频繁的数据: 2.  有利于SEO(搜索引擎优化); 纯的HTML ...

  7. OC中的内省(Introspection)方法

    我们在写OC代码的时候经常用到:isKindOfClass: 一类的方法,但是对于它并没有一个了解,这里也是从网上搜索了一些内容,简单介绍并记录一下.这类方法就是属于OC的特性之一:内省. 内省(In ...

  8. vue组件中,iview的modal组件爬坑--modal的显示与否应该是使用v-show

    这是我第一次写博客,主要是记录下自己解决问题的过程和知识的总结,如有不对的地方欢迎指出来! 需求:点击btn,弹出modal显示图表(以折现图为例) 这应该是很基本的需求也是很容易实现的,代码和效果如 ...

  9. C++ primer第三章作业

    3.1节 练习3.1: 使用恰当的using声明重做1.4.1节(第11页)和2.6.2节(第67页)的练习 #ifdef 1 #include <iostream> using std: ...

  10. CentOS6安装各种大数据软件 第十章:Spark集群安装和部署

    相关文章链接 CentOS6安装各种大数据软件 第一章:各个软件版本介绍 CentOS6安装各种大数据软件 第二章:Linux各个软件启动命令 CentOS6安装各种大数据软件 第三章:Linux基础 ...