当前位置: 首页 > news >正文

P7521 [省选联考 2021 B 卷] 取模 分析

题目概述

给你 \(n\) 个数 \(a_i\)

求:\(\max_{i\ne j\ne k}(a_i+a_j)\bmod a_k\)

分析

好题!

我一开始看到是无从下手的。

但是细想一下,关键点在于 \(a_k\),所以的说,枚举 \(a_k\) 是必不可少的。

然后我们令剩余的数全部对 \(a_k\) 取模,得到答案的途径有两种:

  • \(b_i+b_j\geq a_k\),因为两者相加最多减去一个 \(a_k\),这种情况直接取两个最大的就行了,时间复杂度 \(mathcal{O}(n\log n)\)
  • \(b_i+b_j< a_k\),这个用 \(l,r\) 双指针框住区间取两端即可,相当于枚举 \(l\),那么所对应的 \(r\) 是单调递减的,时间复杂度 \(\mathcal{O}(n\log n)\)

两者都需要先排序。

对于每一个 \(a_k\) 都做一遍这个我们是承担不起的。

那么贪心地先做大的 \(a_k\),这个是显然的。

如果过说我现在的 \(ans\) 不小于当前的模数(因为在此种情况下不可能存在更大的解),直接退出即可。

那么这个剪枝是很强的(还需要注意对于相等的 \(a_k\) 只做一遍,怕那种全都是一样的数据)。

可以证明一下。

代码

时间复杂度 \(\mathcal{O}(n\log V\log n)\)

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <stdlib.h>
#include <vector>
#define int long long
#define N 200005
using namespace std;
int n,a[N],b[N];
int solve(int id) {int cnt = 0;for (int i = 1;i <= n;i ++)if (i != id) b[++cnt] = a[i] % a[id];stable_sort(b + 1,b + 1 + cnt);int res = (b[cnt] + b[cnt - 1]) % a[id];for (int l = 1,r = cnt;l < r;l ++) {while(l < r && b[r] + b[l] >= a[id]) r --;if (l < r) res = max(res,b[l] + b[r]);}return res;
}
signed main(){cin >> n;for (int i = 1;i <= n;i ++) scanf("%lld",&a[i]);stable_sort(a + 1,a + 1 + n,greater<int>());int ans = 0;for (int i = 1;i <= n;i ++) {if (ans >= a[i]) break;if (a[i] == a[i - 1]) continue;ans = max(ans,solve(i));}cout << ans;return 0;
}

证明时间复杂度

假设:

\[a_1>a_2>\dots>a_x>ans>a_{x+1}>\dots>a_n \]

因为 \(ans\) 是最大的答案,根据第一部分我们对于任意 \(i(1\leq i\leq x-2)\) 有:

\[(a_{i+1}+a_{i+2})\bmod a_i\leq ans \]

因为:

\[a_i>a_{i+1}>a_{i+2}>ans \]

所以:

\[(a_{i+1}+a_{i+2})\bmod a_i\leq ans<a_{i+1}+a_{i+2}<2a_i \]

因此我们至少有:

\[a_i\leq a_{i+1}+a_{i+2}<2a_i \]

这就说明了中间的那个式子要是与左边的式子多加上一个 \(a_i\) 比较那肯定是变小的。

我们此时联系上一个式子,把 \(ans\) 换代进来也是一样地有:

\[ans<a_{i+1}+a_{i+2}<ans+a_i \]

注意后面的式子,我们考虑同构,于是左右两边同时减去 \(2ans\) 有:

\[(a_{i+1}-ans)+(a_{i+2}-ans)<a_i-ans \]

同构了!令 \(f_i=a_i-ans\) 那么有:

\[f_{i+1}+f_{i+2}<f_i \]

这很像一个倒着的斐波那契数列,这个东西是呈指数级增长的,所以说是 \(\mathcal{O}(\log V)\) 的时间复杂度。

真神啊这题!

http://www.rkmt.cn/news/25597.html

相关文章:

  • 实用指南:socketpair深度解析:Linux中的“对讲机“创建器
  • 嵌入式硬件——基于IMX6ULL的UART(通用异步收发传输器) - 教程
  • CSP-S 模拟赛 Day 19
  • CSP-S 模拟赛 Day 18
  • 2025年市面上高杆灯品牌与国内公司口碑产品推荐榜单
  • 2025年锥芯板品牌口碑排行榜单Top10:行业精选与选择指南
  • Boost 搜索引擎 - 实践
  • P11233 [CSP-S 2024] 染色题解
  • hive udaf 输入输出处理参考手册 - 指南
  • 位运算(早晚得学会)
  • 深入解析:【C++】继承
  • 20231427田泽航第五周预习报告
  • 利用错误配置的postMessage()函数实现DOM型XSS攻击
  • 机器学习领导者分享AI技术与行业洞见
  • el-upload上传配合$confirm使用的问题
  • 10.20 CSP-S模拟35 改题记录
  • 例子:vue3+vite+router创建导航菜单
  • LGR-246 解题报告
  • (薛定谔のCSP-S)模拟35 2025.10.20
  • CSP-S模拟36
  • 追忆
  • 2025年西服定制厂家权威推荐榜:婚纱/结婚/职业/团体/职场/礼服/工作服/公务员西服定制,专业工艺与个性化服务深度解析
  • luogu P14259 兄妹(siblings)
  • 2025年化工原料厂家推荐排行榜:双氧水/片碱/盐酸/磷酸/PAC/聚丙烯酰胺/消泡剂/阻垢剂等工业级化学品优质供应商
  • 10月20日
  • 结对项目--小学四则运算题目生成器
  • 阿里云智能语音简单使用:语音识别
  • 计数
  • 2025年风机盘管厂家权威推荐榜:两联供室内机/水系统空调室内机/全包围风机盘管/超薄风机盘管/静音风机盘管/半包围风机盘管/单冷源除湿新风机/五恒空调
  • 详细介绍:计算机工作原理(简单介绍)