AGC033

AGC033

听讲着感觉没有做的那套 AGC055 难。主要是套路比较多。

A.Darker and Darker

简单的 BFS 即可。

B.LRUD Game

有两种做法:

  • 逆着考虑,还原可赢的初始区间。

    • 对于先手,当前如果有一个向上走的,那么纵向上界便会被抬高。其他方向类似。

    • 对于后手,与先手相反,会使得范围变小,但是注意一下边界(不可越界)

    • 还要考虑一个问题,先手先走,逆着考虑,后手先走!

  • 模拟博弈的过程:

    • 如果先手确定了一个方向,那么一定不会走反方向。所以考虑枚举方向。

    • 而在 博弈 过程中,后手需要保证,后面不会被先手顺势向同一个方向移出。也就是博弈时所累计的前缀和不能小于先手的后缀和。

C.Removing Coins

题意:

每次选择一个点作为根,删去其叶子结点。

如果只有两个节点,则都删。

我们考虑每一次操作对树造成的影响:影响直径。

如果选择了直径上的点作为根,则会使得直径减2,反之减1。

考虑最终剩余 2 的情况就赢。也就是说,只有直径为 1+3x 的情况,后手才可以胜利。(始终使得为 3 的倍数)。

D.Complexity

不难有 n4 的记忆化搜索(或者DP)。

但是考虑答案的情况,不难得出答案的界为 O(logW+logH)

显然与状态不同界。所以考虑枚举答案。(经典套路)

于是可以有状态:fx,i,j,k 表示答案为 x,上 i,下 j,做 k 时能达到的最大右界。

初始状态,贪心选。

考虑转移:

fx,i,j,k=fx1,i,j,fx1,i,j,kfx,i,j,k=maximjmin(fx1,i,m,k,fx1,m+1,j,k)

考虑优化:

m 其实可以二分求,或者通过决策单调性:

  • fx,i,j,pi,j 一定时,随着 p 单调下降。同理,所以 j 递增,m 递增。

E.Go around a circle

利用生成函数的做法可以参考:agc033_e - myee 的博客 - 洛谷博客

构造递推的方法可以参考:题解 [AGC033E] Go around a Circle - 菜鸟驿站 - 洛谷博客

要仔细分析题目性质,通过增加限制减少决策的方式,解决转化后的问题。

或者说利用限制,从充要条件下手。

F.Adding Edges

神仙做法。参考:AT4929 [AGC033F] Adding Edges - - 洛谷博客

本质上也就是通过的传递进行优化。但这东西真难想的出来。

posted @   jeefy  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
点击右上角即可分享
微信分享提示