ARC130F Replace by average

首先我们能够发现,最终得到的答案 \(b\) 一定为下凸的。但是直接求凸壳肯定不行。具体地,答案的凸壳要满足对于每个 \(x\)\(b_x\) 都是整数,即每段斜率都是整数。

可以发现找到能包住点集,最贴合的一个这样的 \(b\) 数组就是答案,因为题目给定的操作让我们每次都只能扩展最贴紧的点。那么我们先对 \(a\) 求出凸包,然后从 \(b_i\) 推到 \(b_{i+1}\)。即,我们需要找到 \((i,b_{i})\)\(a\) 的凸壳的切线。由于 \(i\) 是递增的,且得到的 \(b\) 也是推的,所以切点是递增的,直接双指针即可。总复杂度 \(O(n)\)

https://atcoder.jp/contests/arc130/submissions/50443191

posted @ 2024-03-26 08:31  LarsWerner  阅读(5)  评论(0编辑  收藏  举报