AGC055

第一次打AGC,好难受。

T1 看了一眼题解,没看懂……但是还是做出来了。

T2 感觉比 T1 简单,构造很好猜。

其他的没时间思考,T1 花了我 2h30min,难受。

A.ABC Identity


翻译

给定长度为 \(3n\) 的序列,其中字母 ABC 各有 \(n\) 个。

一个合法序列 \(T\) 满足以下条件:

  • 其长度为 \(3k (1 \le k \le n)\)。

  • \(T_1 = T_2 = ... = T_k\)

  • \(T_{k + 1} = T_{k + 2} = ... = T_{2k}\)

  • \(T_{2k + 1} = T_{2k + 2} = ... = T_{3k}\)

  • \(T_1, T_{k + 1}, T_{2k + 1}\) 互不相同。

求一个把这个序列分成不多于 \(6\) 个合法的序列的方案。

可以证明,一定存在一种合法的划分。


分三段考虑。

std 做法是关于 ABC 的 6 种排列,依次枚举,贪心选择。

我在考场上是:先考虑前两半,相异配对,网络流解决。

不会产生相同配对的正确性?由于是相异配对,如果产生相同配对,则某一个一定超过了 \(n\) 个,不符合题意。所以网络流可以解决,贪心选择没问题。

网络流只有 \(6 + 2\) 个点,所以可以看作常数,复杂度 + O(1)

所以整体复杂度 \(O(n)\)

妈的,傻逼网络流,真的服……

B.ABC Supremacy

考虑如下转化:

\[A \overline{ABC} \to \overline{ABC} A \\
B \overline{ABC} \to \overline{ABC} B \\
C \overline{ABC} \to \overline{ABC} C
\]

也就是我们贪心把所有的 \(\overline{ABC}\) 放在最前面即可。(相当于删除)

由于拼接后也可能存在 \(\overline{ABC}\),所以利用栈的思想处理。

复杂度 \(O(n)\)。

C.Weird LIS

方法1:组合

参考 AGC055C - Legitimity 的博客 - 洛谷博客 和补充 题解:AGC55C Weird LIS - Edward1002001 的博客 - 洛谷博客

这里再做一点说明。

  • 无用点为什么不可连续?考虑 4 3 5 2 1 7 6,也就是 非 非 必 无 无 非 非。这个排列和 2 1 3 7 6 5 4 ,也就是 非 非 必 非 非 非 非 是等价的。也就是说,连续的 会使得我们重复计数。所以不可以连续。

  • ans 初始设置?其实枚举的是没有必经点的情况(全是非必经点),需要满足:

    • \(k \le \lfloor \frac n2 \rfloor\)

    • \(k \le m\)

    • \(k \ge 2\)

    所以才有 \(\min(m, \lfloor \frac n2 \rfloor) - 1\)。但是我们还需要考虑当 \(m = n - 1\) 时,可以存在全是必经点的情况,也就是 1 2 3 ... n 的情况。

  • 为什么 \(\min(m, x + y) - \max(x, 3) + 1\)?这里枚举的是 \(k\),\(k\) 的下界确定了,因为存在 \(k - 1\),所以 \(k - 1 \ge 2 \iff k \ge 3\)。

其他部分最终式子为:

\[\sum_{x = 1}^{\min(m, n - 1)} \sum_{y = 0}^{\lfloor \frac {n - x}2 \rfloor}
{x + y \choose x} {x + 1 \choose n - x - 2y} (\min(m, x + y) - \max(x, 3) + 1)
\]

方法2:自动机

参考 at_agc055_c Weird LIS 题解 - juruo - 洛谷博客

这里做一点解释:

  • 状态机的设定,4种状态:

    1. 除了 CAN,都能放

    2. 只能放 CAN

    3. 可以放 MUST 或者 USELESS,之后 MUST 还可以跟 MAY

    4. 可以放 MUST 或者 USELESS,之后 MUST 不可以跟 MAY

  • 为什么有状态4?因为 k 确定了红黑对的数量,而我们是贪心的把所有红黑对尽可能放在前面。而可能存在只有 非 非 无 必 的情况,所以有状态 3,通过 MUST 转移到 1,通过 USELESS 转移到 4,但是不能再来一个 MAY

D.ABC Ultimatum

一道猜结论的题。

观察三个串,有 ABCBCACAB,我们考察能划分成这三种串的串的性质。

考虑每一个字母出现的次数:由于 B 只在 BCA 中在 A 前面,其他的类似。我们考虑定义 \(M_B = \max S_B - S_A\),其他的类似。

可以发现,\(M_B \le C_{BCA}\),同理,得到 \(M_A + M_B + M_C \le C_{ABC} + C_{BCA} + C_{CAB} = N\)。

这是必要条件,所以考虑证明充分性(不会。

所以我们可以设出一个 \(O(n^7)\) 的 DP,令 \(f_{a, b, c, x, y, z}\) 表示 ABC 的数量以及 \(M_A, M_B, M_C\)。

不过考虑 \(a + b + c = i\) 的时候才有贡献,所以可以省一维,变为 \(O(n^6)\)。

E.Set Merging

神仙思路题。

我们把整个序列看作一个排列,每一次的合并相当于交换排列中的两个位置。

而最终 \(S_i \to [ \min_{j = i}^n P_j, \max_{j = 1}^i P_j]\),一个后缀 \(\min\) 和一个前缀 \(\max\)。

考虑归纳法,分 \(P_i > P_{i + 1}\) 或者 \(P_i < P_{i + 1}\) 讨论。

最终就是求合法序列的最小逆序对数。考虑贪心放置,用数状数组求。

总复杂度 \(O(n + n \log n)\),可以通过6指针的方法优化到 \(O(n + n)\)。

随机推荐

  1. OS如何保持对计算机的控制权?

    前面我们提到:OS希望在保持控制权的同时,为用户提供高性能的并发. 那么OS究竟是如何保持对计算机的控制权呢?这似乎是一个令人迷惑(但很重要!)的问题:OS也是进程,自然也需要计算资源.那既然我们希望 ...

  2. 力扣1083(MySQL)-销售分析Ⅲ(简单)

    题目: Table: Product Table: Sales 编写一个SQL查询,报告2019年春季才售出的产品.即仅在2019-01-01至2019-03-31(含)之间出售的商品. 以 任意顺序 ...

  3. 力扣571(MySQL)-给定数字的频率查询中位数(困难)

    题目: Numbers 表保存数字的值及其频率. 在此表中,数字为 0, 0, 0, 0, 0, 0, 0, 1, 2, 2, 2, 3,所以中位数是 (0 + 0) / 2 = 0. 请编写一个查询 ...

  4. HarmonyOS NEXT应用开发之预加载so并读取RawFile文件

    介绍 本示例主要介绍在TaskPool子线程中使用 dlopen 预加载 so 库并使用句柄调用库函数的方法,以及在Native中使用 pread 系统函数读取Rawfile文件的部分文本内容,并添加 ...

  5. PolarDB开源未来将有哪些新动向?阿里云数据库开源负责人来解答

    简介: 在10月25日由阿里云开发者社区.PolarDB开源社区.infoQ联合举办的「开源人说」第三期--<数据库PolarDB专场>沙龙上,阿里云数据库开源负责人.数据库资深技术专家王 ...

  6. 宜搭5月更新:跨应用数据读写能力升级,AI组件内测开放

    ​简介:表单.权限管理.AI组件等功能上新啦- 本次,我们带来了表单.权限管理.数据管理.平台管理权限.组件等功能的升级. 表单 支持跨应用数据查询 在使用组件数据联动.关联其他表单数据.关联表单组件 ...

  7. 阿里巴巴在开源压测工具 JMeter 上的实践和优化

    简介:Apache JMeter 是 Apach 旗下的开源压测工具,创建于 1999 年初,迄今已有超过 20 年历史.JMeter 功能丰富,社区(用户群体)庞大,是主流开源压测工具之一. 作者: ...

  8. Serverless 工程实践 | 自建 Apache OpenWhisk 平台

    ​简介: OpenWhisk 是一个开源.无服务器的云平台,可以在运行时容器中通过执行扩展的代码响应各种事件,而无须用户关心相关的基础设施架构. OpenWhisk 简介 OpenWhisk 是基于云 ...

  9. 🎊这个 OpenTiny 开源项目的 CLI 可太牛了,两行命令创建一个美观大气的 Vue Admin 后台管理系统,有手就会,连我的设计师朋友都学会啦啦

    大家好,我是 Kagol,OpenTiny 开源社区运营,TinyVue 跨端.跨框架组件库核心贡献者,专注于前端组件库建设和开源社区运营. 近期尝试了下 OpenTiny 的 CLI 工具,不得不说 ...

  10. RT-Thread 运行时常见错误

    一.空线程栈较小 现象: 现象一: 现象二: 原因: 从RT-Thread文章中心可知,空闲线程是不能被挂起的,官方文档说明如下图所示: 注意:必须保证空闲线程的栈空间足够,否则空闲线程内存溢出后,也 ...