ZOJ 1489 2^x mod n = 1 数论
2024-08-27 23:09:31
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=489
题目大意:
给你正整数n,求最小的x使得2^x mod n = 1。
思路:
n=1无解。任何正数mod 1都为0吧
n为偶数无解,why? 上式可变形为: 2^x=k*n+1,若n为偶数那么k*n+1为奇数,而2^x必为偶数。
n为奇数一定有解,对于乘法逆元:在a mod n的操作下,a存在乘法逆元当且仅当a与n互质。
#include<cstdio>
int main()
{
int n;
while(~scanf("%d",&n))
{
if( !(n & 1) || n==1)
{
printf("2^? mod %d = 1\n",n);
continue;
}
int d=1;
for(int i=1;;i++)
{
d*=2;
if(d%n==1)
{
printf("2^%d mod %d = 1\n",i,n);
break;
}
d%=n;
}
} return 0;
}
最新文章
- 分布式缓存Memcached---开篇的话
- JavaWeb前端:CSS
- Access批量操作
- August 6th, 2016, Week 32nd, Saturday
- 在Linux下安装aws命令行操作
- 帝国CMS商城功能高级使用
- 几年前无聊小游戏之作_WEB版本打泡泡
- Stack栈的三种含义
- Oracle数据库 Synonym和DBLink
- 云栖大会day2总结 上午
- PHP程序员解决问题的能力
- MATLAB 图形着色
- 001-分布式理论-CAP定理
- docker mac
- Jmeter之分布式执行测试
- asp.net 获得域名,端口,虚拟目录[转]
- 97.394570112228 - Query OK, 1 row affected (43.05 sec) - the overhead of parsing and network communication
- mysql_connect
- 【代码笔记】iOS-archive保存图片到本地
- JavaScript 三个常用对话框