luogu#P10071. [CCO2023] Triangle Collection
[CCO2023] Triangle Collection
题目描述
Alice 有一些棍子。一开始,对于每个 ,她有 根长度为 的棍子。
Alice 想用她的棍子做一些等腰三角形。一个等腰三角形由两根长度为 的棍子和一根长度在 和 之间的棍子组成。注意,三根棍子的长度必须严格满足三角形不等式,等边三角形也是满足条件的。每根棍子最多只能在一个三角形里使用一次。Alice 想知道用她的棍子最多能做出多少等腰三角形。
有 个事件改变了她拥有的棍子的数量。第 个事件包含两个整数 和 ,表示长度为 的棍子的数量变化了 。注意, 可以任意整数,但是 Alice 永远不会有负数或者超过 根长度为 的棍子。
你需要求出在每个事件之后,Alice 用她的棍子最多能做出多少等腰三角形。
输入格式
第一行包含两个用空格分隔的整数 和 。
第二行包含 个用空格分隔的整数 ,表示 Alice 的开始时拥有的棍子。
接下来的 行,每行包含两个用空格分隔的整数 和 ,表示一个事件。
保证在每个事件之前和之后,对于每个 ,长度为 的棍子的数量都在 和 之间。
输出格式
输出 行,每行包含一个整数,表示每个事件之后的答案。
4 3
3 1 4 1
3 -3
1 6
2 1
1
3
4
提示
在第一个事件之后,Alice 可以用长度为 的棍子做一个三角形。
在第二个事件之后,Alice 可以用长度为 的棍子做三个三角形。
在第三个事件之后,Alice 可以用长度为 的棍子做三个三角形,并用长度为 的棍子做一个三角形。
对于所有的数据,有 ,,,。
子任务编号 | 分值 | N, Q 的范围 | 额外限制 |
---|---|---|---|
1 | 20 | 在所有时刻,总共最多有 根棍子。 | |
2 | 没有额外的限制 | ||
3 | 在所有时刻,每种长度的棍子的数量只会是 | ||
4 | |||
5 | 没有额外的限制 |