9.27 模拟赛(NOIP十三连测 #10)

news/2024/11/18 3:29:37/文章来源:https://www.cnblogs.com/2huk/p/18436446

2024--梦熊&太戈--NOIP十三连测 #10【订正】 - 比赛 - 梦熊联盟 (mna.wang)

复盘

开 T1。差分转化。模拟了一下样例感觉方案好像是唯一确定的,不需要贪心/DP。但不太能证。

想了会感觉找不出反例。然后写完了。对拍没挂。用时不到 \(30\) 分钟。

T2。\(m \le 20\) 且数据随机感觉很好做的样子。

发现不会正解,但是有 \(50\) 的部分分很快想出来了。先写 \(50\)

T2 正解先放,看 T3。

数位 DP?好像不是。想到了 ABC363D,但好像没关系。

没关系吗?我可以通过 ABC363D 的方法,处理出所有 \(<n\) 的回文数,总共 \(\sqrt n\) 个,然后双指针(其实全存下来再双指针,直接做差判断另一个是否回文即可)。能过 \(n \le 10^{12}\)\(50\) 分!写!

然后对拍没挂。尝试卡常通过 \(n \le 10^{16}\)\(70\) 分但失败了。

开 T4。不是第二档部分分直接按题意模拟啊,这种红题难度的部分分给了 \(30\)??

第一档倍增也会。有 \(60\) 了。正确性显然所以没对拍。

\(260\) 了。冲 T2 正解。

我好像忘了数据随机。于是加了一些针对随机优化。一个比较重要的是将前面的数去重。然后跑自己造的 \(n = 10^6,m=20\) 的随机数据。

1.6s。

不是啊????????????我是不是过了。

显然没过。最终 \(100+50+60+60=270\)。T3 \(n \le 10^{16}\) 多过了一个点。没离谱挂分就是胜利!

其实 T2 只要再加一个优化就过了。但我好像想到了(?)但是感觉不太好写(?)所以没写。

总结

好的:

  • 想出了 T1。
  • 没挂分。

不足:

  • 不会乱搞。

题解

A. 小 C 玩扑克

注意到区间 \([i, r_i]\) 最多只会反转 \(1\) 次。

区间反转可以差分转化,然后变成单点修改 \(i\)\(r_i + 1\),直到差分序列全变成 \(0\)。令差分序列为 \(b\)

注意到每个区间是否需要反转是唯一确定的。考虑归纳证明。

对于 \(j\),我们希望让 \(b_j\) 最终变成 \(0\),也就是说如果 \(b_j\) 原来是 \(1\) 的话,需要执行奇数次与 \(j\) 有关的操作(与 \(j\) 有关指对 \(i = j\)\(i = r_j + 1\) 进行操作)。如果 \(b_j\) 原来是 \(0\) 则偶数。

我们考虑所有满足 \(r_i + 1 = j\)\(i\)。因为 \(i \le r_i\) 所以这些区间是否反转已经确定了,且我们假设到现在都没出现过问题。

求出这些 \(i\) 中有多少个反转过。如果这个数量的奇偶性与 \(b_j\) 不相同,那么 \(i = j\) 的操作必须进行一遍。

所以我们就唯一确定了每个区间是否反转。所以输入的 \(t_i\) 是诈骗,只在算答案的时候用了。

B. 小 C 写代码

显然这不是个贪心/DP题。我们只需要算每一行的最小代价,加和即可。

两种做法。

暴力+优化

代码比文字好理解。复杂度是 \(\mathcal O(n 2^{2m})\),但是数据随机所以非常快(0.3s)。

bool st[2 * N];
vector<int> v[N];int solve() {for (int i = 0; i < 1 << m; ++ i )v[ppc(i)].push_back(i);int res = 0;for (int i = 1; i <= n; ++ i ) {int x = 0;for (int j = 0; j < m; ++ j ) {char c = getchar();while (c != '1' && c != '0') c = getchar(); x = x * 2 + c - '0';}if (st[x]) res ++ ;else {int p = c;for (int j = 0; j <= m; ++ j )for (int k : v[j])if (st[x ^ k]) {p = min(p, j + 1);break;}st[x] = true;res += p;}}return res;
}

正解

\(f(S)\) 表示通过当前已经编写的代码,变成 \(S\) 的最小代价。初始 \(f(S) = c\),即第一种编写代码方式。

我们要支持对 \(f\) 进行操作:

  • 查某个特定的 \(f(S)\)
  • 编写一行新的代码,并修改所有 \(f(S)\)

注意到 \(f(S) \le m\)。所以第二种操作里,所有 \(f(S)\) 最多只会总共变化 \(\mathcal O(m2^m)\)

考虑搜索。类似 SPFA,只有当 \(S\)\(f\) 变优时进行松弛,若没变优直接停止搜索。

所以复杂度是 \(\mathcal O(m^22^m)\)。因为每个状态修改一个点后能得到 \(m\) 个不同的,所以又多了一个 \(m\)

提交记录 #633164 - 梦熊联盟 (mna.wang)

C. 对称数之和

考虑 \(\mathcal O(2^{\log_{10}n})\) 枚举每一位是否进位,处理出 \(m_i\) 表示最终的 \(a, b\) 需要满足 \(a,b\) 的第 \(i\) 位和为 \(m_i\)。这里因为已经考虑好进位了所以有可能 \(m_i \ge 10\)

分类讨论:

  • 如果 \(a, b\) 位数相同:

    • 如果 \(m\) 不回文那么答案是 \(0\)

    • 否则,每个对应位单独计算贡献,乘法原理即可。

      具体的,如果这一位两个数的和是 \(m_i\),那么:

      • 如果 \(m_i \le 9\):方案数是 \(m_i + 1\)。因为 \(a_i\) 可以取 \(0 \sim m_i\)
      • 如果 \(m_i > 10\):方案数是 \(9-(m_i-9)+1=19-m_i\)。因为 \(a_i\) 可以取 \(m_i - 9 \sim 9\)
  • 如果 \(a, b\) 位数不同:

    \(a, b\) 中必有一个与 \(m\) 有相同位数。不妨设为 \(a\),最后将方案数乘 \(2\)

    枚举 \(b\) 的位数(\(1 \sim m_i - 1\))。满足如上条件的 \(a, b\)在至多只有一个。因为如果存在那么必定是这种形式:

    这是一个例子。其实就是通过做差和回文转移得到的。

    得到这个后判断一遍是否所有条件都合法即可。

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

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

相关文章

软件工程第一次结对作业之需求分析和原型设计

这个作业属于哪个课程 https://edu.cnblogs.com/campus/fzu/SE2024这个作业要求在哪里 https://edu.cnblogs.com/campus/fzu/SE2024/homework/13261这个作业的目标 设计一个兼顾实用性、有效性、安全性、隐私性和封闭性的跨专业项目合作平台,为大学生提供便捷的合作渠道,解决…

Linux 防火墙与安全管理工具详解

Linux 防火墙与安全管理工具详解 1. Iptables 概述 Iptables 是 Linux 系统中用于控制网络流量的工具,通过定义规则来过滤、转发和修改数据包。其规则可以细致地管理进入和离开系统的数据流。 1.1 三表五链1.1.1 三表 Iptables 中主要有三种表,每种表用于不同的操作:filter …

PS 2024下载

下载链接 https://pan.baidu.com/s/12CPOer87t83ytwZ0MC5tIQ?pwd=7x3s 7x3s是提取码 1.百度网盘保存后下载到本地电脑用解压软件解压,解压密码是ruanjianhenye 2.打开解压后的文件夹,鼠标点击set-up选择以管理员的身份运行3.选择更改位置4.打开需要将软件安装的磁盘(如…

Excel读写之xlrd模块

1.1、xlrd模块介绍 xlrd:用于读取Excle数据文件将返回的数据对象放到内存中,然后查询数据文件对象的相关信息。 xlwt:用于在内存中生成新的数据文件对象,处理完成后写入到Excel数据文件中。 xlutils:主要的作用就是copy新的文件对象,在新的数据对象中完成数据处理操作。 …

广州C++信奥老师解一本通题 1919:【02NOIP普及组】选数

​【题目描述】已知nn个整数x1,x2,……xn 以及一个整数K(K<n)。从n个整数中任选K个整数相加,可分别 得到一系列的和。例如当n=4, k=3 4个整数分别为3,7,12,19 3, 7,12,19时,可得全部的组合与它们的和为: 3+7+12=22   3+7+19=29   7+12+19=38  3+12+19=34 现在,要求你计算…

VMware安装Ubuntu操作系统 2024.9.27

1.安装 Ubuntu的官方网站是:https://www.ubuntu.com/download 点进去可以直接下载文件下载会比较慢,我这点用了约5分钟 然后就可以打开vmware,选择:就可以注册和使用了。 笔记本电脑是这样的。。 如果使用台式机,没有相应的硬件环境的话,就不要创建空的盘符了,就可以创建…

PbootCMS上传图片失败或提示:未知错误

在PbootCMS中,如果遇到上传图片失败或提示“未知错误”,可以尝试以下几个步骤来解决问题: 解决方案 1. 检查服务器空间和权限检查服务器空间:确认服务器空间是否已满。可以使用FTP客户端或服务器管理面板查看剩余空间。 如果空间不足,清理一些不必要的文件或增加空间容量。…

五上数学第1单元情况反馈204班

五上数学第1单元情况反馈204班 本周进行了数学第一单元的综合练习,已经进行了讲评。试卷已经下发,请学生带回家改完错误,家长签字。 签字在试卷的左上角,签字示范:家长阅,9月27日,或者再写一些建议与意见都可以。 下面分析一下第一单元的情况: 第一单元是本册最难的单元…

地平线静态目标检测 MapTR 参考算法-V1.0

1.简介 高清地图是自动驾驶系统的重要组件,提供精确的驾驶环境信息和道路语义信息。传统离线地图构建方法成本高,维护复杂,使得依赖车载传感器的实时感知建图成为新趋势。早期实时建图方法存在局限性,如处理复杂地图元素的能力不足、缺乏实例级信息等,在实时性和后处理复杂…

20240927 随机训练

GYM 105350 E 题目描述 给定一个大小为 \(N\) 的数组 \(A\)。 我们定义一个大小为 \(N\) 的数组 \(B\) 是有效的当且仅当:对于 \(\forall 1\le i\le N,1\le B_i \le N\),如果从 \(B\) 中移除 \(B_i\),则数组 \(B\) 恰好有 \(A_i\) 个不同的数。求有多少个不同的由有效数组 \…

apisix实现四层转发

背景 来水一篇文章,其实官网都有,论如何在apisix上实现四层转发 什么是apisix apisix是动态、实时、高性能的 API 网关,构建于 OpenResty 之上,支持热加载配置、灰度发布、蓝绿部署等功能,同时具有良好的可扩展性和易用性。 管理接口参考 参考:(以2.4版本为例) https:/…