1 条题解
-
0
自动搬运
来自洛谷,原作者为

ARIS2_0
路虽远,行则将至;事虽难,做则必成。搬运于
2025-08-24 23:09:28,当前版本为作者最后更新于2025-02-06 08:31:46,作者可能在搬运后再次修改,您可在原文处查看最新版自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多
以下是正文
前言
赛时被小黄题创飞了,写个题解长长教训。
思路
设 为 的 的个数, 为 的 的个数。
则对于一个数 ,它的最大出现次数为:
$$\sum_{i=1}^{10^9}\sum_{j=1}^{10^9}\min(c_i,d_j)[i\times j\bmod M=x] $$注意到这里取 是正确的,因为 且 是质数,所以对于 ,不存在 使得 。
所以,如果有 ,那 乘其他数、 乘其他数都不能得到 ,所以可以取 。
那么,我们枚举满足 的 与 的 ,计算出 ,然后将 加上 ,最后计算 数组中的最大值就可以了。
数组需要用
unordered_map实现,时间复杂度 ,常数稍大。Code
经过少许压行,马蜂不好还请见谅。
#include<bits/stdc++.h> using namespace std; #define pii pair<int,int> unordered_map<int,int>c,d,ans; int main(){ int n;cin>>n; for(int i=1,p;i<=n;i++)cin>>p,c[p]++; for(int i=1,p;i<=n;i++)cin>>p,d[p]++; for(pii i:c)for(pii j:d)ans[1ll*i.first*j.first%1000000007]+=min(i.second,j.second); int pos=0;for(pii i:ans)pos=max(pos,i.second);cout<<pos; }
- 1
信息
- ID
- 10893
- 时间
- 3000ms
- 内存
- 256MiB
- 难度
- 3
- 标签
- 递交数
- 0
- 已通过
- 0
- 上传者