USACO 2023 January Contest, Platinum 题解

Tractor Paths

题意:给定 n 个不交区间,两个区间之间有边当且仅当这两个区间的交非空。Q 次询问,每次给定 u,v,求从 uv 的最短路和最短路可能经过的点点权和。n,Q2×105

题解:求最短路是简单的,每次从 u 开始,每次贪心跳到尽可能右边的区间,直到跳过 v,这个可以用倍增维护。考虑可能经过的点,我们将 u 贪心右跳直到跳出 vv 贪心左跳直到跳出 u 的路线画出来,发现其实就是对应的 len 个区间和查询,这个也可以倍增维护。

Mana Collection

题意:有 n 个能量池,第 i 个能量池每秒增加 mi 能量,能量池之间有一些边 (u,v,w),表示从 uvw 秒。经过一个能量池时可以取出所有能量并清空这个能量池的能量,Q 个询问,给定 s,e,询问 s 秒内最终停在 e 处取出的能量最多多少。n18,Q2×105,s109

题解:取出最多能量就是没取出的能量最少。状压 DP,记录经过了哪些能量池,加入一个新的能量池时贡献是到这个能量池的时间乘上之前就经过了的能量池的 mi 之和,因为经过的我们肯定不会再经过了,这些能量就浪费了。离线处理询问,本质上是很多个直线,求一个点的最值,用类似李超树的分治即可,或者求凸包也行。

Subtree Activation

题意:有一个 n 个点树,初始时每个点都是暗的,一次操作可以反转一个点,要求对每个 uu 的子树全部点亮,且 u 子树外的点全部暗,至少一次,并且最终所有点都是暗的,问最少操作次数。n2×105

题解:考虑一个点肯定会被开关开关若干次。用 dpu,i 表示 u 这个点,可以免费开关开关 i 次,(开算 1 次,关也算 1 次),子树每个点都被完成过的代价。然后这个免费开关是可以分给子树的,当然你也可以付费开关,这样会导致代价增加,子树多一次免费开关的机会,转移是个树形背包的形式。大胆猜测开关次数是 O(logn) 的,树背包是 O(nm) 的,因此复杂度 O(nlogn)

posted @   xay5421  阅读(103)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示