2021HDU多校第九场1008HDU7073 Integers Have Friends 2. 随机化

HUD地址:https://acm.hdu.edu.cn/showproblem.php?pid=7073

 题目大意:选择数组中最多的数,使得他们模m同余(m>=2)。求最大的数量。

思路:然后我们全选奇数或者全选偶数的话,那么我们的答案是最少是n/2的,所以我们随机两个下标,他们都在正确答案的集合里的概率就为1/4,当我们随机k次时,失败的概率就是(3/4)^k,是非常小的,所以这个随机策略是可行的,知道两个数后,我们可以得到他们直接的差t,那么这个正确集合的m必然是t的质因子,所以我们分解t的质因子,对于每一个质因子我们o(n)去计算出他的答案,而4e12最多只有11个质因子,所以复杂度为O(k*11*n),分解质因子是根号级别的,预处理出根号4e12大小的质数就行了。

#include <cstdio>
#include <cstring>
#include <string>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <queue>
#include <cstdlib>
#include <stack>
#include <vector>
#include <set>
#include <list>
#include <map>
#include <unordered_map>
#include <bitset>
#include <time.h>
#include <random>#define INF 0x3f3f3f3f3f3f3f3f
#define inf 0x3f3f3f3f
#define endl '\n'
#define FILL(a,b) (memset(a,b,sizeof(a)))
#define lson rt<<1
#define rson rt<<1|1
#define lowbit(a) ((a)&-(a))
#define ios std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);
#define fi first
#define sc second
#define pb push_back
#define all(x) (x).begin(),(x).end()
using namespace std;
typedef long long  ll;
typedef unsigned long long  ull;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;
const ll mod=998244353;
const ll N =3e5+5;
const double eps = 1e-8;
const double PI=acos(-1);
ll gcd(ll a,ll b){return !b?a:gcd(b,a%b);}
ll re(){ll x;scanf("%lld",&x);return x;}
ll mul(ll a, ll b, ll m){ll ans = 0;a %= m;while(b){if(b & 1)ans = (ans + a) % m;b /= 2;a = (a + a) % m;}return ans;}
ll qk(ll a,ll b,ll mod){ll ans=1;while(b){if(b&1) ans=ans*a%mod;a=a*a%mod;b/=2;}return ans;}
int dx[8]= {1,0,-1,0,1,1,-1,-1}, dy[8] = {0,1,0,-1,1,-1,1,-1};
template <class T>T _rand(T l, T r) // 生成随机数建议用<random>里的引擎和分布,而不是rand()模数,那样保证是均匀分布{static mt19937 eng(time(0));if (l > r)swap(l, r);uniform_int_distribution<T> dis(l, r);return dis(eng);}ll ans;
ll a[N],n;
vector<ll> p;
bool st[2000010];
void get(int n){st[0]=st[1]=1;for(int i=2;i<=n;i++){if(!st[i]) p.push_back(i);for(int v:p){if(v*i>n) break;st[v*i]=1;if(i%v==0) break;}}
}
void solve() {cin>>n;for(int i=1;i<=n;i++) cin>>a[i];ans=1;for(int r=1;r<=30;r++){int x= _rand(1ll,n);int y= _rand(1ll,n);if(x==y) continue;ll m=abs(a[x]-a[y]);if(m!=1){for(int v:p){if(v>m) break;if(m%v==0){while (m%v==0) m/=v;ll sum=0;for(int i=1;i<=n;i++){ll k=abs(a[x]-a[i]);if(k%v==0) sum++;}ans= max(ans,sum);}}if(m!=1){ll sum=0;for(int i=1;i<=n;i++){ll k=abs(a[x]-a[i]);if(k%m==0) sum++;}ans= max(ans,sum);}}}cout<<ans<<endl;
}int main()
{iosint T=1;cin>>T;get(2000000);while (T--) solve();return 0;
}

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

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

相关文章

一个引发程序员们干架的问题

这里是Z哥的个人公众号每周五早8点 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「77」篇原创敬上在一个分布式系统的开发团队中&#xff0c;有一些问题是很容易产生程序员之间矛盾的。其中之一就是「业务归属」&#xff0c;就是当新加/修改一个业务的时候&a…

newcode Islands 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个圆&#xff0c;上面依次有nnn个点&#xff0c;编号为1−n1-n1−n的排列&#xff0c;给出一种连边方式&#xff0c;使得每个点都被遍历且连线不能相交&#xff0c;没有方式的话输出−1-1−1。 思路&…

微服务探索与实践—服务注册与发现

前言微服务从大规模使用到现在已经有很多年了&#xff0c;从之前的探索到一步步的不断完善与成熟&#xff0c;微服务已经成为众多架构选择中所必须面对的一个选项。服务注册与发现是相辅相成的&#xff0c;所以一般会合起来思索。其依托组件有很多&#xff0c;比如Zookeeper,Co…

快速沃尔什变换:从入门到背板(含推导过程)

前&#xff08;che&#xff09;言&#xff08;dan&#xff09; FWTFWTFWT是个神奇的东西。 然而网上多数讲解多数直接给结论&#xff0c;顶多用归纳法证一证。 所以本文会讲解FWTFWTFWT的推导过程。 虽然也用到了构造&#xff0c;但是好背得多 参考博客&#xff1a;https:/…

微服务探索与实践—总述

背景软件开发是一个不断发展的过程&#xff0c;从当初的面向过程为主到如今的面向对象的开发&#xff0c;软件开发者不断探索与实践更加符合时代发展要求的开发模式与架构思想&#xff0c;而这&#xff0c;也在极大程度上提高了软件开发的效率。微服务是一种架构模式或者说是架…

P4097 [HEOI2013]Segment 李超线段树

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 实现以下两个操作&#xff1a; (1)(1)(1)在平面上加入一条线段。记第iii条被插入的线段的标号为iii (2)(2)(2)给定一个数kkk&#xff0c;询问与直线xkxkxk相交的线段中&#xff0c;交点纵坐标最大的线段的编…

【CF1204D】Kirk and a Binary String【结论题】【LIS】

传送门 题意&#xff1a;给一个01串SSS&#xff0c;求一个等长的01串TTT SSS和TTT所有对应位置的子串最长不下降子序列长度&#xff08;以下简称LIS\text{LIS}LIS&#xff09;相同TTT中0的数量尽量多 ∣S∣≤100000|S| \leq 100000∣S∣≤100000 对于一个01串SSS&#xff0c;…

这周,全球首个IT技术全中文免费学习平台诞生了!太惊艳!

本周三的Developer Wednesday为大家揭秘了Microsoft Learn网站的全新学习模式一时间Microsoft Learn圈粉无数如果你正在为错过直播而暴风哭泣等一等&#xff0c;看这里&#xff01;全程高清回播将为你持续解密这一次你一定不可以再错过了哦&#xff01;什么是Microsoft Learn&…

【CF1182D】Complete Mirror【树的重心】

传送门 题意&#xff1a;给一棵NNN个结点的树&#xff0c;你需要钦定一个根&#xff0c;使得所有深度相同的点的度数相同。 N≤100000N \leq 100000N≤100000 用脑子想一想&#xff0c;就是根节点直接相连的子树都长得一模一样。 如果根节点度数大于1&#xff0c;我们发现它…

P1989 无向图三元环计数 思维 + 建图

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 统计无向图中三元环的个数。 思路&#xff1a; 很明显有一种暴力的方法&#xff0c;就是枚举每条边&#xff0c;让后再跑两个点的所有边&#xff0c;可以卡到复杂度O(m2)O(m^2)O(m2)。 我们可以考虑给点之…

十分钟了解Kubernetes

何为Kubernetes?最简单的一句话来概括Kubernetes。它就是一套成熟的商用服务编排解决方案。Kubernetes定位在Paas层&#xff0c;重点解决了微服务大规模部署时的服务编排问题。Kubernetes组件介绍了解Kubernetes都是从Pod开始的。Pod是Kubernetes最小的调度单元&#xff0c;所…

【CF1020C】Election【贪心】

传送门 题意&#xff1a;NNN个人给MMM个党派投票&#xff0c;开始时每个人选择一个党派投票&#xff08;给定&#xff09;&#xff0c;每个人可以花费一定代价贿赂&#xff08;每个人给定代价&#xff09;&#xff0c;求让1号党派胜出&#xff08;票数严格最大&#xff09;的最…

Codeforces Round #627 (Div. 3) E. Sleeping Schedule dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一天hhh小时&#xff0c;初始时间是000&#xff0c;每天可以使时间aia_iai​或者ai−1a_i-1ai​−1&#xff0c;问最多可以让多少天的时间在[l,r][l,r][l,r]范围内。 思路&#xff1a; 算是个比较简单…

【CF1194E】Count The Rectangles【类扫描线】【单调性】【树状数组】

传送门 题意&#xff1a;给定NNN条与坐标轴平行的线段&#xff0c;保证不垂直的线段没有交点&#xff0c;求一共构成多少个矩形&#xff08;以线段交点为顶点&#xff09;。 1≤N≤50001\leq N\leq50001≤N≤5000 显然是个数据结构乱搞题。 直觉告诉我们先枚举一条线段。 假…

.NET Core 的过去、现在和未来

在最新的微软 Build 大会主题网站上&#xff0c;微软.NET 程序经理 Scott Hunter 发表了一篇文章&#xff0c;指出.NET Core 是.NET 的未来。去年&#xff0c;微软就已经确认 Visual Studio Live 中的.NET 框架将会被.NET Core 取代。将.NET Core 作为开源开发技术栈在 2014 年…

Ozon Tech Challenge 2020 (Div.1 + Div.2) C. Kuroni and Impossible Calcul 抽屉原理

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组ana_nan​&#xff0c;求∏1≤i<j≤n∣aj−ai∣modm\begin{matrix} \prod_{1\le i<j\le n} |a_j-a_i| \end{matrix}\bmod m∏1≤i<j≤n​∣aj​−ai​∣​modm。 n≤2e5,m≤1e3n\le2e5…

【HAOI2015】按位或【Min-Max容斥】【FWT】

传送门 题意&#xff1a;开始时你有一个数000,每次选出[0,2n−1][0,2^n-1][0,2n−1]中的一个数进行按位或&#xff0c;每个数选中的概率给定。求得到2n−12^n-12n−1的期望操作次数。 1≤n≤201\leq n\leq 201≤n≤20 神仙题 首先发现每一位都是独立的&#xff0c;可以分开考…

Visual Basic 兴衰记

这是一篇暴露年龄的文章。为什么这么说&#xff1f;因为现在年轻的程序员可能没有接触过当年红极一时的 Visual Basic。28 年前的 1991 年 4 月&#xff0c;Microsoft 发布了 Visual Basic 1.0 for Windows&#xff0c;次年 9 月&#xff0c;发布了 Visual Basic 1.0 for DOS。…

Ozon Tech Challenge 2020 (Div.1 + Div.2, Rated) D. Kuroni and the Celebration 交互 + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一颗树&#xff0c;每次可以询问两个点的lcalcalca&#xff0c;询问次数不能超过⌊n2⌋\left \lfloor \frac{n}{2} \right \rfloor⌊2n​⌋&#xff0c;求它的根。 n≤1e3n\le1e3n≤1e3。 思路&#xf…

【CF1047D】Little C Loves 3 II【构造】【赛瓦维斯特定理】

传送门 题意&#xff1a;给一个NMN \times MNM的空棋盘&#xff0c;每次选取两个曼哈顿距离为3的空格子放上棋子&#xff0c;问最多能放多少个。 1≤N,M≤1e91 \leq N,M \leq 1e91≤N,M≤1e9 暴力讨论 假装N≤MN \leq MN≤M ①N1N1N1 容易得到&#xff0c;详见代码 ②N2N…