[JSOI2016]灯塔/[POI2011]Lightning Conductor
2021-02-04 17:15
标签:有一个 扫描 删除 row 超越 algorithm upload 踢出 代码 点这里看题目。 直接变换式子: 显然,\(|i-j|\)可以拆分成\(i 考虑到\(\sqrt{n}\)的增长速度随\(n\)的增大而减小,因此会存在“后来的决策点超越前面的决策点”的情况,但绝不存在“前面的决策点超越后来的决策点”的情况。 设\(f_i(n)=\sqrt{n-i}+h_i\),那么我们就正在求解\(\max_{j\le i}\{f_j(i)\}\)。 下图展示了样例中\(f\)函数的情况: 可以发现,两个\(f\)函数最多有一个交点。那么,对于两个函数,我们就可以二分出它们交点的\(x\)坐标(没有交点的,我们视为交点在无限远处)。那么,当扫描的下标\(i\)越过了交点之后,先来的决策点就会被踢出去,后来的决策点就比它更优。 样例中,\(f_4\)和\(f_2\)的交点的\(x\)坐标为\(\frac {17} 4\)。这意味着,当\(i时,\(f_2\)更优;否则\(f_4\)更优。 根据上述性质,每个决策点最多会被弹出一次。因此我们可以想到用队列维护决策点集合。对于每个决策点\(k\),我们处理出它什么时候会被它后面一个决策点弹出去,记为\(d_k\)。在新扫描到一个位置的时候,我们先将这个位置从队尾加入到决策点集合,并把那些比它劣的决策点全部弹掉。然后再查询当前的答案,先把队头的变劣的决策点弹掉(惰性删除),然后再计算。 时间复杂度\(O(n\log_2n)\)。 [JSOI2016]灯塔/[POI2011]Lightning Conductor 标签:有一个 扫描 删除 row 超越 algorithm upload 踢出 代码 原文地址:https://www.cnblogs.com/crashed/p/13138111.html题目
分析
代码
#include
文章标题:[JSOI2016]灯塔/[POI2011]Lightning Conductor
文章链接:http://soscw.com/essay/50986.html