CF1753
CF1753
成功因为虚拟机炸了,重新写一遍此文。
都是没有保存的错。
A. Make Nonzero Sum
由于 Note that it is not required to minimize the number of segments in the partition.。考虑每一段最小化……
可以发现,每一段都可以划分为长度为 1 或 2 的段。于是考虑影响。
只有长度为 2 的段会改变正负,不妨令 \(C_+, C_-\) 分别表示 1 和 -1 的个数,并假定 1 更多。
不难发现,只需要 \(\frac {|C_+ - C_-|}2\) 个长度为 2 的即可。
如果不是整数,那么直接判不可以即可。
由于有影响,考虑 DP。
设 \(f_i\) 表示考虑前 \(i\) 个数,最多能够放多少个长度为 2 的。
于是有
f_{i - 1} \\
f_{i - 2} + 1 &, a_i = 1
\end{cases}
\]
考虑在 DP 变化的地方放置长度为 2 的即可。
B. Factorial Divisibility
当时脑子抽了,用了两种合并的方法。
但是实际上只需要通过 \(x! = x \times (x -1)!\) 合成即可(2048……
C. Wish I Knew How to Sort
假定有 \(C_0\) 个 \(0\),并且在前 \(C_0\) 个数中有 \(k\) 个 1。
那么考虑此时一个有效的操作,即是在前 \(C_0\) 中选择到了一个 \(1\),在后面中选择了一个 \(0\)。
有效的概率为
\]
于是考虑状态转移,设 \(f_k\) 表示从前 \(C_0\) 个数中有 \(k\) 个 \(1\) 的状态转移到 \(0\) 个 \(1\) 的期望步数。
根据 markov 中的期望线性方程求解的方法,有
\]
稍微魔改一下,就变成了:
\]
于是小小递推即可。
然而我当时是反着推的,无所谓,一样的:Submission #211560140 - Codeforces
D. The Beach
转换问题:等价于将两个 . 移动到一起的最小代价。
显然可以发现,一个障碍最多移动一次。
借用大佬的图:
于是我们可以考虑如此建图。跑一个最短路即可。
提交:Submission #211566195 - Codeforces
E. N Machines
非常恶心,虽然不是顶级难度。
最优的策略一定是把乘法向后移,把加法向前移。
思考 It's guaranteed that the current value of the resulting product does not exceed 2x10^9. 的意义。
发现,除去 \(\times 1\),最多只会有 \(\log C\) 个乘法。
于是考虑枚举其子集,为 \(2^{\log C}\)。所以需要优化。
有一个简单而优雅的剪枝:如果两个数相等,那么一定是选择最前面的。
由于 \(12! = 6227020800 \gt 2 \times 10^9\),所以其实最多只会有 \(O(2^{12})\) 种状态。
那么在钦定了向后移动的乘法后,我们需要找到前 \(rest\) 个移动到前面贡献最大的加法。
考虑二分移动到前面的贡献 \(\Delta\),在每一段再二分数量。
考虑如何计算每一个加法的 \(\Delta\) ?考虑加法移动前,其贡献为 \(x \times suf_x\),移动后的贡献为 \(x \times pre_x \times suf_x\)。
其中 \(suf_x\) 和 \(pre_x\) 是指乘法移动后,\(x\) 前面的乘法前缀积和后面的乘法后缀积。
于是 \(\Delta x = x \times (pre_x - 1) \times suf_x\)。
NOTICE:
二分 \(\Delta\) 时找到最大的 \(cnt > rest\) 的那个 \(\Delta\),由于多算了 \(cnt- rest\) 个,并且这些数的贡献一定是 \(\Delta\),所以再减去 \((cnt - rest) \times \Delta\) 即可。
\(\Delta\) 可能很大很大,所以上界大一点(我用的倍增,所以直接是从 \(2^{60}\) 开始向下……虽然没必要)
提交:Submission #211609810 - Codeforces
F. Minecraft Series
首先固定一个正方形,考虑贡献:将数分为正数与负数,分别计算 \(mex_p\) 与 \(mex_n\)。
正的为
positive,负的为negative。
于是贡献为 \(mex_p + mex_n - 1\)。
由于 \(mex\) 的单调性,发现包括合法正方形的正方形一定合法,所以考虑双指针维护所在最小合法正方形的。
注意,是在每一条对角线上来一发双指针,这样才能保证复杂度。
然后,然后就搞定了。
可以优化的是,\(mex\) 可以利用分块优化复杂度。
于是你可以得到一个复杂度为:
\]
的优雅 brute force……
提交:https://codeforces.com/contest/1753/submission/211685792
然而……不断的 TLE 让我怀疑人生,最后发现……
参考:讨论
随机推荐
- C#的窗体假关闭操作例子 - 开源研究系列文章
晚上编码的时候,想到了以前编写的窗体关闭的事情,就是带托盘图标的应用,有一个主显示操作窗体,但是主窗体点击关闭按钮的时候,实际上是窗体隐藏而非真正关闭,这个在其它的一些应用程序里有这个效果.于是就想到 ...
- 力扣59(java)-螺旋矩阵Ⅱ(中等)
题目: 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix . 输入:n = 3 输出:[[1,2,3],[8,9,4],[ ...
- 牛客网-SQL专项训练16
①在book表中,将工具书类型(tool)的书的书架序号都减少2,下列语句正确的是(C) 解析: 题目要求的批量更改,insert 是更改数据,排除B,update与set搭配使用,排除选项D,whe ...
- [ABC342D] Square Pair 题解
[题目描述] 给定一个长度为 \(N\) 的非负整数序列 \(A=\left(A_1,\cdots,A_n\right)\).求满足以下条件的整数对 \(\left(i,j\right)\) 的数量. ...
- iLogtail社区版使用入门 - 采集MySQL Binlog
简介: MySQL Binlog记录了MySQL的变更日志,业界也有一些方案来同步Binlog的数据,如Canal.MaxWell.DTS等.不同的工具可以实现不同的目标,iLogtail也提供了便捷 ...
- MAE 自监督算法介绍和基于 EasyCV 的复现
简介:自监督学习(Self-Supervised Learning)能利用大量无标注的数据进行表征学习,然后在特定下游任务上对参数进行微调.通过这样的方式,能够在较少有标注数据上取得优于有监督学习方 ...
- 与容器服务 ACK 发行版的深度对话第二弹:如何借助 hybridnet 构建混合云统一网络平面
简介:本次采访我将继续为大家详细讲解我的好伙伴:阿里巴巴的开源 Kubernetes 容器网络解决方案 hybridnet,以及我是如何借助它来构建混合云统一网络平面. 作者:若禾.昱晟.瑜佳 记者: ...
- Docker Desktop v20.10.8 和 WSL2 迁移镜像存储目录
只迁移存储镜像和挂载文件目录:https://www.cnblogs.com/lemonK/p/17781775.html 同时迁移docker程序目录:https://www.cnblogs.com ...
- [GPT] 网页中某些dom内容是通过 js 数据异步渲染的,nodejs 怎么获取网页解析这些数据
要处理使用JavaScript异步渲染内容的网页,您可以在 JavaScript 蜘蛛中使用 Puppeter 或 Playwright 等无头浏览器来获取网页,然后与动态渲染的内容进行交互. 下 ...
- [Blockchain] 前后端完全去中心化的思路, IPFS 与 Ethereum Contract
我们在使用智能合约的时候,一般是把它当成去中心.减少信任依赖的后端存在. 如果没有特殊后端功能要求,一个 DApp 只需要前端驱动 web3js 就可以实现了. 可以看到,现在前端部分依旧是一个中心化 ...
