luogu#P10071. [CCO2023] Triangle Collection

[CCO2023] Triangle Collection

题目描述

Alice 有一些棍子。一开始,对于每个 l=1,,Nl=1, \ldots, N,她有 clc_{l} 根长度为 ll 的棍子。

Alice 想用她的棍子做一些等腰三角形。一个等腰三角形由两根长度为 ll 的棍子和一根长度在 112l12 l-1 之间的棍子组成。注意,三根棍子的长度必须严格满足三角形不等式,等边三角形也是满足条件的。每根棍子最多只能在一个三角形里使用一次。Alice 想知道用她的棍子最多能做出多少等腰三角形。

QQ 个事件改变了她拥有的棍子的数量。第 ii 个事件包含两个整数 lil_{i}did_{i},表示长度为 lil_{i} 的棍子的数量变化了 did_{i}。注意,did_{i} 可以任意整数,但是 Alice 永远不会有负数或者超过 10910^{9} 根长度为 ll 的棍子。

你需要求出在每个事件之后,Alice 用她的棍子最多能做出多少等腰三角形。

输入格式

第一行包含两个用空格分隔的整数 NNQQ

第二行包含 NN 个用空格分隔的整数 c1,c2,,cNc_{1}, c_{2}, \ldots, c_{N},表示 Alice 的开始时拥有的棍子。

接下来的 QQ 行,每行包含两个用空格分隔的整数 lil_{i}did_{i},表示一个事件。

保证在每个事件之前和之后,对于每个 l=1,,Nl=1, \ldots, N,长度为 ll 的棍子的数量都在 0010910^{9} 之间。

输出格式

输出 QQ 行,每行包含一个整数,表示每个事件之后的答案。

4 3
3 1 4 1
3 -3
1 6
2 1
1
3
4

提示

在第一个事件之后,Alice 可以用长度为 (1,1,1) (1,1,1) 的棍子做一个三角形。

在第二个事件之后,Alice 可以用长度为 (1,1,1)(1,1,1) 的棍子做三个三角形。

在第三个事件之后,Alice 可以用长度为 (1,1,1)(1,1,1) 的棍子做三个三角形,并用长度为 (2,2,3)(2,2,3) 的棍子做一个三角形。

对于所有的数据,有 1N,Q2×1051 \leq N, Q \leq 2\times 10^50ci1090 \leq c_{i} \leq 10^{9}1liN1 \leq l_{i} \leq N109di109-10^{9} \leq d_{i} \leq 10^{9}

子任务编号 分值 N, Q 的范围 额外限制
1 20 1N,Q20001 \leq N, Q \leq 2000 在所有时刻,总共最多有 20002000 根棍子。
2 没有额外的限制
3 1N,Q2×1051 \leq N, Q \leq 2\times 10^5 在所有时刻,每种长度的棍子的数量只会是 1,2,31,2,3
4 di=1,1d_{i}=1,-1
5 没有额外的限制