[Neerc2016]Expect to Wait

Time Limit: 10 Sec Memory Limit: 128 MB

Description

ls最近开了一家图书馆,大家听说是ls开的,纷纷过来借书,自然就会出现供不应求的情况,并且借书的过程类

似一个队列,每次有人来借书就将它加至队尾,每次有人来还书就把书借给队头的若干个人,定义每个人的等待时

间为拿到书的时刻减去加至队列的时刻,如果一个人根本就拿不到书,则等待时间为inf,现在给出所有时刻借书

还书的情况,和若干个询问,每次询问当图书馆初始有x本书时所有人的等待时间之和是多少(如果存在一个人根

本拿不到书,则输出INFINITY)。

Input

第一行两个整数\(n,q(1<=n,q<=100000)\),表示有\(n\)个时刻有借书还书的情况,以及有\(q\)个询问。

接下来\(n\)行,每行表示一个操作,操作如下:

1.$"+\ t\ k" $ 在\(t\)时刻有\(k\)本书被还回来。

2.\("-\ t\ k"\) 在\(t\)时刻有\(k\)个人来借书。

\((1<=t<=1e9,1<=k<=10000)\)

输入顺序保证t递增。

接下来一行\(q\)个数,第\(i\)个数\(b_i(1<=b_i<=1e9)\)表示图书馆初始有\(b_i\)本书,询问所有人的等待时间之和为多少。

Output

一共\(q\)行,每行一个数表示等待时间之和,如果存在一个人根本拿不到书,则输出INFINITY。

Sample Input

\(5 \ 4\)

\(- \ 1 \ 1\)

\(- \ 2 \ 2\)

\(+ \ 4\ 1\)

\(- \ 6 \ 1\)

\(+ \ 7 \ 2\)

\(0 \ 3 \ 1 \ 2\)

Sample Output

\(INFINITY\)

\(0\)

\(8\)

\(3\)

不要问我为什么是数据结构。。。。据说可以用线段树???(雾)

好了,来讲一讲这道题。。。。

最开始头是真的铁。。。。。我就要在线操作。。。。我就要!!!!

凉凉夜色为你思念成河????

然后我们只有来重新看这道题。。。。

我们首先把这道题转化一下,我们用正数和负数来分别表示两种情况。。。。正数的意思是你现在有多少本书。。。。负数的意思是现在有多少个人在等。。。。。

感觉很友好的翻译了一下题目。

那么我们要求的是一个数列中,有多少个小于0的数(每个数分别乘上它对应的权值)。

然而你会发现不是那么友好。。。。显然坑坑洼洼,七零八碎的。。。。怎么统计啊。。。。

但是你又会发现每次询问都是对于整个数列的,,整个,,整个。。。。。。

也就是说,数列的顺序并没有什么影响。

排序啊!!!!

排序的好处在于,整个数列是单调递增的以后,需要你统计的答案就变成连续一段的了。。。

维护前缀和来统计答案吧。。。。。

把询问离线下来,排个序。也满足单调性啦~~~

具体看代码的啦(结构体有一点鬼畜,yy一下就好)


#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 5;
struct lpl{
int num, len;
bool operator < (const lpl &aaa)const{
return num < aaa.num;
}
}a[maxn], b[maxn], lin[maxn];
int n, q, last, cnt;
long long ans[maxn], s[maxn], sl[maxn];
char mark[911]; inline void putit()
{
scanf("%d%d", &n, &q);
for(int i = 1; i <= n; ++i){
scanf("%s%d%d", mark, &lin[i].num, &lin[i].len);
if(mark[0] == '-') lin[i].len = -lin[i].len;
a[i].num = a[i - 1].num + lin[i].len;
a[i - 1].len = lin[i].num - lin[i - 1].num;
}
} inline void workk()
{
last = a[n].num; sort(a + 1, a + n + 1);
for(int i = 1; i <= n; ++i){
s[i] = s[i - 1] + (long long)a[i].num * a[i].len;
sl[i] = sl[i - 1] + a[i].len;
}
for(int i = 1; i <= q; ++i) scanf("%d", &b[i].num), b[i].len = i;
sort(b + 1, b + q + 1); int cnt = n;
for(int i = 1; i <= q; ++i){
if(last + b[i].num < 0){ans[b[i].len] = -1; continue;}
while(cnt && a[cnt].num + b[i].num > 0) cnt--;
ans[b[i].len] = -s[cnt] - b[i].num * sl[cnt];
} } inline void print()
{
for(int i = 1; i <= q; ++i)
if(ans[i] == -1) printf("INFINITY\n");
else printf("%lld\n", ans[i]);
} int main()
{
putit();
workk();
print();
return 0;
}

bzoj4843 [Neerc2016]Expect to Wait的更多相关文章

  1. 【BZOJ4843】[Neerc2016]Expect to Wait 排序

    [BZOJ4843][Neerc2016]Expect to Wait Description ls最近开了一家图书馆,大家听说是ls开的,纷纷过来借书,自然就会出现供不应求的情况, 并且借书的过程类 ...

  2. 「Neerc2016」Expect to Wait

    题目描述 ls最近开了一家图书馆,大家听说是ls开的,纷纷过来借书,自然就会出现供不应求的情况, 并且借书的过程类 似一个队列,每次有人来借书就将它加至队尾,每次有人来还书就把书借给队头的若干个人,定 ...

  3. expect用法

    1. [#!/usr/bin/expect]  这一行告诉操作系统脚本里的代码使用那一个shell来执行.这里的expect其实和linux下的bash.windows下的cmd是一类东西.  注意: ...

  4. expect基本使用方法

    参考: http://www.cnblogs.com/lzrabbit/p/4298794.html expect是linux系统中可以和子进程进行交互的一个命令,使用它可以做一些自动化工作.pyth ...

  5. expect实现自动登录

    自动登录主机(ssh) 建脚本item2login.sh,包含如下内容 #!/usr/bin/expect set timeout 30 spawn ssh -p [lindex $argv 0] [ ...

  6. 自动化运维 Expect

      Mac 下载:brew install homebrew/dupes/expect expect : ->  自动化脚本工具:  用于处理交互命令; #注意 调用时并不是使用的 /bin/b ...

  7. expect

    #!/usr/bin/expect -fset ipaddr "192.168.5.4"set passwd "123qwe"set timeout 30 sp ...

  8. expect命令问题1

    [root@localhost scripts]# cat exptest.sh #!/usr/bin/expect spawn ssh root@127.0.0.1 expect "pas ...

  9. expect脚本语言用法示例

    #!/usr/bin/expect set hostname [lindex $argv 0] set username [lindex $argv 1] set passwd [lindex $ar ...

随机推荐

  1. PHP算法[转]

    这里是用PHP写的几个基础算法,算法的重要性貌似对于PHP程序员不怎么重要,其实是非常重 要的,经典名句:算法+数据结构=程序.作为一名真正的高级PHP程序员,我认为应该熟悉C,如果你想成为真正的程序 ...

  2. 各种条码的校验码算法(EAN13,COD128,GTIN,UCC等)

    校验码是由编码方案决定的,所以在代码中是否使用校验码和条码基本无关,但商品条码除外.今天给大家介绍几种校验码的计算方法. 一.商品条码: 商品条码中需要计算校验码的有:EAN-8(8位),EAN-13 ...

  3. Beta-星期五

    所属课程 https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass 作业要求  https://edu.cnblogs.com/camp ...

  4. Notepad++安装Zen Codingt插件

    Zen Coding介绍 Zen Coding是一套面向文本编辑器的插件,它允许通过IDE工具的联想功能(内容辅助)高速度的编辑HTML.XML.XSL和其他结构化的代码格式. Zen Coding由 ...

  5. 消费者与生产者---LinkedList方式模拟

    采用LinkedList数据结构方式来模拟消费者与生产者模型,小Demo import java.util.LinkedList; public class MyQueue { private fin ...

  6. 前后端分离下的CAS跨域流程分析

    写在最前 前后端分离其实有两类: 开发阶段使用dev-server,生产阶段是打包成静态文件整个放入后端项目中. 开发阶段使用dev-server,生产阶段是打包成静态文件放入单独的静态资源服务器中, ...

  7. STM32F103系列命名规则

    对于STM32F103xxyy系列:第一个x代表引脚数:T-36pin,C-48pin,R-64pin,V-100pin,Z-144pin:第二个x代表Flash容量:6-32K,8-64K,B-12 ...

  8. C# 批量修改考勤设备时间

    自己工作中用到的小程序,每次远行后批量改一次 如下: 其中的zkemkeeper是中控的相关组件,因是系统组件,须要先注册相关文件后才有效 using System; using System.Col ...

  9. Python的list中的选取范围

    a = [1,2,3,4,5,6,7,8,9,10] a[0:1] = [1] a[0:2] = [1,2] 包含开头,不包含结尾. a [:-1]: 从头一直到最后一个元素a[-1],但不包含最后一 ...

  10. hihocoder 1014: Trie树(Trie树模板题)

    题目链接 #include<bits/stdc++.h> using namespace std; ; struct T { int num; T* next[]; T() { num=; ...