十连测 8C

(私题)http://zhengruioi.com/contest/1485/problem/2734

容易想到 \(O(n^2)\) dp:设 \(dp_{i,j}\) 表示前 \(i\) 大的 \(x\) 与前 \(j\) 大的 \(y\) 所在的 pair 已被取走时的最小代价。转移时考虑第 \(i+1/j+1\) 大的 \(x/y\) 是否已经被取走,若是则不花费代价,否则花费对应代价即可。即钦定在第一次拿到某物品时花费代价。

但是这东西没什么优化空间啊!状态数卡的很死,且转移也不是很能优化。

考虑挖掘一些性质。

换个角度想,我们其实就是在钦定每个 pair 是选 \(x\) 还是 \(y\),只不过由于选法的特殊性,有一些选择的方式是不合法的。考虑按某种顺序依次考虑每一个 pair 的选取决策,寻找一些关于合法性的约束:

  • 若比当前 pair \(x\) 更大的 pair 还未选完,当前 pair 无法选择 \(x\)

  • 若比当前 pair \(y\) 更大的 pair 还未选完,当前 pair 无法选择 \(y\)

  • 若存在非偏序点对 \((a,b)\),设 \(a_x<b_x,a_y>b_y\),此时不能出现 \(a\) 选取 \(x\)\(b\) 选取 \(y\) 的决策。

发现前两条其实是没什么用的,第三条则是有关当前局面合法性的充要条件

考虑以 \(x\) 升序,设 \(dp_{i,j}\) 表示前 \(i\) 个 pair 选取后,选 \(x\) 的 pair 中最大的 \(y=j\) 的最小代价,此时若下一决策 \((x',y')\) 中的 \(y'>j\) 则可以该 pair 可以选取 \(y\)\(x\),否则只能选取 \(x\)。此时有转移方程:

\[\begin{cases}dp_{i+1,j}=dp_{i,j}+x,&y\le j\\dp_{i+1,y}=dp_{i,j}+x,&y> j\\dp_{i+1,j}=dp_{i,j}+y,&y>j\end{cases} \]

我们发现该转移方程刚好是以 \(y\) 隔开的三段转移,用线段树维护即可,时间复杂度 \(O(n\log n)\)

posted @ 2023-11-02 16:11  ydtz  阅读(35)  评论(0编辑  收藏  举报