10.22 —— 2024icpc沈阳D,E,B,M

news/2025/10/23 13:00:50/文章来源:https://www.cnblogs.com/jjjxs/p/19157779

D. Dot Product Game

首先将对两个数组的操作转变为对一个数组的操作:可以发现,\(a\) 的某个子数组循环左移 \(r\) 位 与 对 \(b\) 的某个子数组循环右移 \(r\) 位是等价的,因此修改某个情形,只需要对其中一个序列的子数组循环左移或右移即可。

我们可以到,最终答案一定由序列的奇偶性决定(感觉这个猜还是比较容易想的)。证明也比较容易:一个经典结论是,交换任意排列的任意两个不同的数,逆序对数的奇偶性一定发生改变,而由于交换的两个位置 \(i, j\) 必须满足:\(a_{i} * b_{i} + a_{j} * b_{j} < a_{i} * b_{j} + a_{j} * b_{i}\),化简得:\((a_{i}-a_{j})(b_{i}-b_{j}) < 0\),可以等价于:\((i-j)((ba^{-1})_{i} - (ba^{-1})_{j}) < 0\)\(ba^{-1}\)\(a,b\) 作为置换复合后形成的环)。和 \(21\)\(ccpc\) 桂林 \(D\) 一样,可以看出我们只能交换原序列中的逆序对,进一步可得知每次操作后,逆序对数必然减少,最终一定会减为 \(0\)。而由于每次操作必然会导致逆序对数奇偶性的改变,因此可推导:操作次数的奇偶性等于逆序对数的奇偶性。

因此问题缩小为 带修动态维护序列逆序对数的奇偶性。

如果修改和查询操作没有什么特殊性,那这个问题应该没有什么解法。但由于修改一定是将某个子数组循环左移或右移,并且只是查询逆序对数的奇偶性,我们可以发现,每循环左移(或右移)子数组 \(a[l,r]\) 一步,逆序对的奇偶性是否改变与 \(r-l\) 的奇偶性有关,因为一次循环左移操作等价于将第一个元素移动到其他元素之后,而它们的数量是 \(r-l\)。因此得出结论:对于子数组 \(a[l,r]\), 循环左移/右移 \(d\) 步,逆序对奇偶性是否改变取决于 \(d(r-l)\) 的奇偶性。 修改操作不需要真正模拟一遍,每次只需要 \(O(1)\) 查询即可,总复杂度 \(O(n)\)

code

E. Light Up the Grid

这道题的状态转移有点把蒟蒻弄糊涂了,补了很长时间才补出来。

开始时想到了逆向着求单源最短路,但状态表示远远没有蒟蒻想得那么简单,因为并没有要求所有初始状态在同一操作过程中 同时到达 全1状态,而是只要经历过就可以。因此状态表示就需要特殊考虑。由于整张图只是一个 \(2 \times 2\) 大小,总共只有 \(16\) 种状态,因此可以考虑对图的所有情形进行状压。可以设状态 \(dp_{state}:\),目前仍存在二进制状态 \(state\) 表示的所有图还没有到达过全 \(1\) 状态(每一个二进制位代表一个 \(2 \times 2\) 矩阵,填充恰好与当前二进制位数相同),要使得它们均到达全 \(1\),最小总代价。

在状态转移时,只需要注意当某个状态转移到全 \(1\) 时,就可以消除掉这个状态,其他未到达的状态直接转移即可。最后问题就等价于给定所有初始图对应的二进制状态到达 \(0\) 的最短路,直接从 \(0\) 开始求一遍单源最短路即可。复杂度 \(O(2^{16})\)

code

B. Magical Palette

一道比较考验数学的构造题,思路和官解一模一样。

code

M. Gitignore

大致思路是没问题的,但忘记了当环的总边权和为 \(0\) 时也不可行。本题的关键是在于判断某个强连通分量内是否存在一个非 \(0\);而强连通分量的总边权和为 \(0\) 并不代表不存在非 \(0\) 环,这一点需要特别注意。

判断一个强连通分量内部是否存在一个非 \(0\) 环:由于强连通分量内部的点两两可达,因此可以考虑指定一个起点出发,遍历所有点和边,看是否可以找到非 \(0\) 环。在指定起点后,可以直接用 \(dfs\)\(bfs\) 记录每个点到起始点的距离 \(dist\);在遍历点 \(u\) 的出边时,若一个点 \(v\) 再次被搜索到,就代表找到了 \(v\) 所在的其中一个环,其中 \(dist[u] - dist[v]\) 代表环内除了边 \(w(u,v)\) 外的所有边权和;那么该环是非 \(0\) 环当前仅当 \(dist[u] - dist[v] + w = 0\)。按上述方法搜索,每个点和每条边均只会遍历一次,复杂度 \(O(n + m)\)

每个询问 \(O(1)\) 查询即可,总复杂度 \(O(n + m + q)\)

code

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/944187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AGV 系统的内部物流与装配智能化方案设计:应用场景与核心优势详解 - 实践

AGV 系统的内部物流与装配智能化方案设计:应用场景与核心优势详解 - 实践2025-10-23 12:55 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: …

报表过滤框设置默认组织提示死循环

原因:首次赋值当前组织时,BeforeSetItemValueByNumber中过滤范围权限,导致赋值失败,组织字段重新为空,又触发值更新,再次赋值。 解决:实体服务规则中不勾选“值更新”,即值更新时不触发。

第九章-NOP Team dmz-C

第九章-NOP Team dmz-C 1、攻击者通过攻击DMZ-B机器发现有密钥可以免密登录到DMZ-C机器里,,然后攻击者上传了一个挖矿程序,请将该挖矿程序的名称提交, 我们使用DMZ-B下载的私钥进行登录查看当前pytho版本启用交互式…

高级语言设计第二次作业

这个作业属于哪个课程:https://edu.cnblogs.com/campus/fzu/gjyycx 这个作业要求在哪里: https://edu.cnblogs.com/campus/fzu/gjyycx/homework/13570 学号:102500309 姓名:郑睿杰 一、课后练习:(具体思路都在代…

UiPath License

UiPath Lincense: 22年之前,一个独立的OC license官价是2万美金。 22年到25年, UiPath推行了一套Flex的license类型,特点是OC可以免费安装使用,但各个独立的产品license的价格做了上调,比如attened robot, unatte…

一些变换

这篇文章主要是做一个总结和铺垫。 我们做物理题时,常常要解一些复杂的微分方程(便便),但是我们对方程做一些变换往往会使微分方程变成线性方程,这是好的,于是专门研究一些变换是重要的。 一些记号 \[\begin{ali…

ANOMALYCLIP

对象无关的零样本异常检测 创新点有三个:(1)对象不可知文本提示关注图像的异常/正常,而不是对象语义;(2)文本编码器调优来优化原始文本空间;(3)DPAM(V-V)通过增强局部视觉语义来提高分割性能。 论文主要用…

vue项目浏览器内存不断增加

项目中用的jeecg-boot,排除其他内存泄漏的原因,最后发现将右侧点击组件Contextmenu改为v-if显示,内存就降下去了

基于伪距差分定位技术实现方案

基于伪距差分定位技术实现方案,包含原理详解与C++代码实现,结合差分修正与最小二乘解算算法一、定位原理详解 1.1 差分定位基本原理 核心原理:基准站已知精确坐标,计算伪距观测值与真实几何距离的差值(Δρ) 通过…

prometheus服务的客户端

prometheus服务的客户端环境 服务端 192.168.164.110 客户端 192.168.164.1111 添加主机到prometheus服务 # 客户端运行node-exporter docker run -itd \ -p 9100:9100 \ -v /:/rootfs:ro \ -v /sys:/sys:ro \ --name…

AI 辅助开发工具

一、引言:为什么 AI 辅助开发越来越重要?提升开发效率(代码生成、调试、文档) 降低认知负荷(自动补全、上下文理解) 加速学习新技术(解释代码、生成示例) 趋势:AI 成为现代开发者“第二大脑”二、主流 AI 辅助…

网安人必看!2025年最硬核的20+变现路径,学生党也能月入4位数。 - 详解

网安人必看!2025年最硬核的20+变现路径,学生党也能月入4位数。 - 详解pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: …

SightAI 企业级实战:构建高可用、低成本的 AI 应用架构 - sight

在 AI 技术飞速发展的当下,不少开发者已能熟练运用 SightAI 完成个人开发项目。然而,当 AI 应用从个人开发场景迈向企业生产环境时,一系列新的挑战便随之而来,稳定性、成本、安全与合规成为企业必须攻克的难关。本…

应用安全 --- 安卓加固 之 软件安装白名单

应用安全 --- 安卓加固 之 软件安装白名单有些软件会在手机或pda中限制安装其他软件来保证自身软件安全。

应用安全 --- 安卓加固 之 软件安装白名单

应用安全 --- 安卓加固 之 软件安装白名单有些软件会在手机或pda中限制安装其他软件来保证自身软件安全。

Go开发者必备:5款提升代码质量的顶级Linter工具

https://baijiahao.baidu.com/s?id=1840292747265997661&wfr=spider&for=pc

函数作用域在解决 JavaScript 自定义元素类跨环境兼容问题中的应用

JavaScript 自定义元素类作为 Web Components 标准的核心组成部分,其跨环境兼容性依赖于对作用域规则的深刻理解与灵活运用。函数作用域作为 JavaScript 中变量可访问范围的基本划分单位,直接影响自定义元素类在不同…

零知IDE——基于STM32F407VET6和雨滴传感器的多界面TFT降雨监测显示系统 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

React-router v6学生管理系统笔记 - 教程

React-router v6学生管理系统笔记 - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "M…

NOIP模拟赛R8

NOIP模拟赛R8NOIP模拟赛R8 A 绷,看错题导致自己被硬控 1 个小时。 其实也还好,题目问你最多可以被分成多少段,按照贪心不难想到要尽可能让每一段的和变小。 这个时候考虑前缀和 \(sum_i\),不难发现,如果要一段的和…