传送门
先将括号序列建树。
具体而言,假设当前根结点为 ,当前括号序列为 。若 能分成 组括号,则 有 个儿子。对于第 个儿子,以它为新根结点,第 组括号为新括号序列,递归建树。
例如 (()())(())
建出来的树长这样:

同时,在每个结点上记录它代表的括号序列中第一个左括号的权值,作为这个结点的权值。 的权值记为 。
题目中给出的两个操作可以对应到树上的操作。
操作一:交换相邻两颗子树,无代价。
操作二:选定两个儿子 ,将 作为 的儿子, 的子孙们都变成 的儿子。代价为 。称为 “下降” 操作。
形象点:

题目最终的要求是花费最小的代价让这棵树变成链。
先给出一个结论:一定存在最优解,先对浅的结点下降,再对深的结点下降。
证明很简单,因为先下降浅的结点的后续可能性包含了所有先下降深的结点的后续可能性。所以先下降浅的结点一定不差。
下面分类讨论。
时很显然,答案为 。
时,给出一个贪心方法。假设当前层有 个结点 ,且 。我们先依次选定 ,让 下降。然后选定 让 下降。
这一层花费是 。
而我们知道这一层总归是需要留下一个结点的。但是如果留下的不是 ,可以换成 ,这样更深的层花费会更少。因此按照这个贪心就行了。
时,每一层的花费是这一层所有要下降的结点权值和。如果选择下降 ,不仅本层的花费最小,而且对未来也更优。
最后是 ,这种情况是最难的,因为如果下降权值小的,对未来更优,但是留在本层的要收费,对现在不优;如果下降权值大的,对未来不优。
我们加几个定义:
假设最后链长为 。 表示处理第 层时第 层有多少个结点, 表示处理第 层时权值最小的结点的权值, 表示留了一个权值为 的在第 层。
则总修改代价 ,其中 表示所有节点的权值和。
这个式子是怎么推出来的?对于第 层,最终留下 ,最优决策就是让 把其他结点都下降,然后让 下降 。因此本层的最优决策是 。于是总修改代价就是 层的代价求和。
我们的目标是使 最小,因为 为常数,所以就等价于让 最小。
当 时,我们可以贪心地每次让本层的最小值和最大值都下降,随便留下一个其他的就行了。因为留下哪一个其实对总代价没影响,而下降最小值可以让未来的 更小,下降最大值可以让 尽可能的大。
于是我们解决了 的情况, 就结束了,只剩 的情况。
这个时候我们再补充一个观察: 数组一旦开始下降,就会一直下降。
为什么呢?因为每一层下降只会减少一个结点,连只减少 都无法挽回,说明下一层没有结点了。既然没有结点,就会一直下降直到成链。
于是 的情况一定是连续的,也就是某一层 ,然后两个结点中连着一个结点,这个结点又连着一个 …… 直到某一个结点有两个儿子, 了,这之前 。
我们称 的部分为上部分,比上部分深的部分为下部分。显然上部分会有一个结点下降到下部分,记这个结点为 ;同时记下部分中最大值为 (不包括上部分下来的 )。上部分与下部分的分界层为 。
当 ,总花费为 ,其中 为上部分的权值之和, 为下部分的权值之和。手推一下就行。
发现 抵消掉了, 和 都是固定的,所以我们选择下降最小的下去,这样能让 更小。
当 ,总花费类似刚刚的式子: 。抵消后剩一个 ,而且因为 ,下部分最大的都比 小了, 也不可能对 有贡献了,所以肯定要 越大越好。
至此, 的情况也解决了。那整个问题也就解决了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!