题目描述

有一个密码箱,0到n-1中的某些整数是它的密码。 且满足,如果a和b都是它的密码,那么(a+b)%n也是它的密码(a,b可以相等) 某人试了k次密码,前k-1次都失败了,最后一次成功了。 问:该密码箱最多有多少不同的密码。

输入格式

第一行n,k
  下面一行k个整数,表示每次试的密码
  保证存在合法解

输出格式

一行,表示结果
输入样例
  42 5
  28 31 10 38 24
输出样例
  14
提示
  1<=k<=250000 k<=n<=10^14

分析

首先不可能存在存在两个密码互质(这一点想了我半天

如果有两个密码互质,那么0到n-1就都是密码

证明

设两个密码分别为a,b,根据扩展欧几里得定理,以下方程肯定有解

$$ax+by=1$$

从而得知以下方程有解

$$ax+by\equiv1(mod \ n)$$

虽然题目中只能用加法,x与y可能小于0,但是因为

$$a(x+kn)+b(y+kn)\equiv ax+by\equiv1(mod \ n)$$

我应该是第一个在模运算中用连等的人

所以可以推出,如果有两个互质的密码,那么1也是密码

那么通过1自己加自己可以得出0到n-1都是密码

所以不存在互质的密码

用刚才的方法还可以一般性地证明,对于两个密码a与b,gcd(a,b)一定是密码

可以把gcd(a,b)看成万恶之源,它的倍数都是密码,进而衍生出了所有的密码。

如果一个数不是密码,那么它就绝对不是那个最小gcd的倍数

所以我们可以去枚举最小的gcd,验证是否可行。

显然gcd越小越好。

两种思路,一种是枚举后一个个验证,另一种是先去掉前k-1个数的约数再枚举。

Code 1

#include<cstdio>
#include<algorithm>
using namespace std;
int k;long long n,a[],ans;
long long gcd(long long a,long long b){return !b?a:gcd(b,a%b);}
int check(long long x)
{
for(int i=;i<=k;i++)if(a[i]%x==)return ;
return ;
}
int main()
{
scanf("%lld%d",&n,&k);
for(int i=;i<=k;i++)scanf("%lld",&a[i]),a[i]=gcd(a[i],n);long long x=a[k];
sort(a+,a+k);k=unique(a+,a+k)-a-;
for(long long i=;i*i<=x;i++)if(x%i==)
{
if(check(i)){printf("%lld\n",n/i);return ;}
if(check(x/i))ans=n/(x/i);
}
printf("%lld",ans);
}

Code 2

#include<cstdio>
#include<algorithm>
using namespace std;
int k;
long long n,en,cnt,ans,a[],p[],q[],pri[];
inline long long gcd(long long a,long long b){return !b?a:gcd(b,a%b);}
int main()
{
scanf("%lld%d",&n,&k);
for(int i=;i<=k;i++)scanf("%lld",&a[i]);
a[k]=gcd(a[k],n);
for(int i=;i<k;i++)a[i]=gcd(a[i],a[k]);
for(int i=;1ll*i*i<=a[k];i++)if(a[k]%i==)
{q[++en]=i;if(1ll*i*i!=a[k])q[++en]=a[k]/i;}sort(q+,q++en);
long long x=a[k];
for(int i=;1ll*i*i<=x;i++)if(x%i==){pri[++pri[]]=i;while(x%i==)x/=i;}
if(x!=)pri[++pri[]]=x;
for(int i=;i<k;i++)p[lower_bound(q+,q+en+,a[i])-q]=;
for(int i=en;i>=;i--)
{
if(p[i])
for(int j=;j<=pri[];j++)
if(q[i]%pri[j]==)p[lower_bound(q+,q+en+,q[i]/pri[j])-q]=;
}
cnt=;while(p[cnt])cnt++;
printf("%lld\n",n/q[cnt]);
}

【洛谷】P3518 [POI2011]SEJ-Strongbox的更多相关文章

  1. 洛谷 P3518 [POI2011] SEJ-Strongbox 题解

    思路: 首先先将每个输入的数据与n的最大公约数求出(因为如果a[i]是密码,那么所有a[i]与n最大公约数的倍数也是密码:于是如果a[i]不是密码,那么所有a[i]与n最大公约数的倍数也都不是密码)再 ...

  2. 洛谷P3513 [POI2011]KON-Conspiracy

    洛谷P3513 [POI2011]KON-Conspiracy 题目描述 Byteotia的领土被占领了,国王Byteasar正在打算组织秘密抵抗运动. 国王需要选一些人来进行这场运动,而这些人被分为 ...

  3. [洛谷P3527] [POI2011]MET-Meteors

    洛谷题目链接:[POI2011]MET-Meteors 题意翻译 Byteotian Interstellar Union有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1 ...

  4. BZOJ2212或洛谷3521 [POI2011]ROT-Tree Rotations

    BZOJ原题链接 洛谷原题链接 线段树合并裸题. 因为交换子树只会对子树内部的逆序对产生影响,所以我们计算交换前的逆序对个数和交换后的个数,取\(\min\)即可. 对每个叶子节点建一棵动态开点线段树 ...

  5. 洛谷P3515 [POI2011]Lightning Conductor(动态规划,决策单调性,单调队列)

    洛谷题目传送门 疯狂%%%几个月前就秒了此题的Tyher巨佬 借着这题总结一下决策单调性优化DP吧.蒟蒻觉得用数形结合的思想能够轻松地理解它. 首先,题目要我们求所有的\(p_i\),那么把式子变一下 ...

  6. 洛谷 P3527 [POI2011]MET-Meteors 解题报告

    P3527 [POI2011]MET-Meteors 题意翻译 \(\tt{Byteotian \ Interstellar \ Union}\)有\(N\)个成员国.现在它发现了一颗新的星球,这颗星 ...

  7. 洛谷 P3521 [POI2011]ROT-Tree Rotations 解题报告

    P3521 [POI2011]ROT-Tree Rotations 题意:递归给出给一棵\(n(1≤n≤200000)\)个叶子的二叉树,可以交换每个点的左右子树,要求前序遍历叶子的逆序对最少. 大体 ...

  8. 洛谷P3521 [POI2011]ROT-Tree Rotation [线段树合并]

    题目传送门 Tree Rotation 题目描述 Byteasar the gardener is growing a rare tree called Rotatus Informatikus. I ...

  9. 洛谷P3527 [POI2011]MET-Meteors [整体二分]

    题目传送门 Meteors 格式难调,题面就不妨放了. 分析: 一道整体二分的练手题. 就是一般的整体二分的套路,但是要注意,将修改和询问加入队列的时候要先加修改再加询问.另外,博主代码打得太丑,常数 ...

  10. [洛谷P3521][POI2011]ROT-Tree Rotations

    题目大意:给一棵$n(n\leqslant2\times10^5)$个叶子的二叉树,可以交换每个点的左右子树,要求前序遍历叶子的逆序对最少.输出最少的逆序对个数 题解:线段树合并,对于每个节点求出交换 ...

随机推荐

  1. 【转载】C#中List集合使用Last方法获取最后一个元素

    在C#的List集合操作过程中,如果要获取List集合中的最后一个元素对象,则一般会先通过获取到list集合的个数Count属性,然后再使用索引的方式获取到该集合的最后一个位置的元素信息.其实在Lis ...

  2. 【转载】 C#中List集合使用InsertRange方法在指定的位置插入另一个list集合

    在C#的List集合操作过程中,如果在集合中的某个位置插入一个新的元素对象,可以使用Insert方法进行操作.其实List集合也提供了在特定的位置插入另一个集合,然后另一个集合的数据整个写入到当前集合 ...

  3. MFC_选择目录对话框_选择文件对话框_指定目录遍历文件

    选择目录对话框 void C资源共享吧视频广告清理工具Dlg::OnBnClickedCls() { // 清空编辑框内容 m_Edit.SetWindowTextW(L""); ...

  4. Java关于 class类的基础方法

    Class类的方法 1. getClasses 和 getDeclaredClasses getDeclaredClasses 获取到类里所有的的class ,interface 包括了private ...

  5. LeetCode算法01 Valid Parentheses

    Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ...

  6. mysql57重新安装后无法再次启动mysql57服务“本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动。”--解决方法

    本地计算机上的MySQL服务启动后停止.某些服务在未由其他服务或程序使用时将自动. (win10,mysql5.7+) 解决方法: 第一步:查看MySQL57安装路径 只要在programData路径 ...

  7. Computer Vision_33_SIFT: A novel point-matching algorithm based on fast sample consensus for image registration——2015

    此部分是计算机视觉部分,主要侧重在底层特征提取,视频分析,跟踪,目标检测和识别方面等方面.对于自己不太熟悉的领域比如摄像机标定和立体视觉,仅仅列出上google上引用次数比较多的文献.有一些刚刚出版的 ...

  8. 使用awstats分析nginx日志

    1.awstats介绍 本文主要是记录centos6.5下安装配置awstats,并统计nginx访问日志 1.1 awstats介绍 awstats是一款日志统计工具,它使用Perl语言编写,可统计 ...

  9. VueCli3 使用 NutUI (按需加载、定制化主题)

    创建vue.config.js module.exports = { css: { loaderOptions: { // 给 sass-loader 传递选项 scss: { // @/ 是 src ...

  10. windows系统开机执行文件

    以下都是在windows系统下执行的 开机自启程序 新建xxx.bat的文件 编辑自己的bat文件,将所要加载的项目引导进来 注意: 如果有相对路径的话,就需要先加载项目,在用python 执行脚本程 ...