hdu1395 2^x mod n = 1
来源:互联网 发布:阿里云 saas应用 编辑:程序博客网 时间:2024/04/29 01:15
2^x mod n = 1
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 12312 Accepted Submission(s): 3848
Problem Description
Give a number n, find the minimum x(x>0) that satisfies 2^x mod n = 1.
Input
One positive integer on each line, the value of n.
Output
If the minimum x exists, print a line with 2^x mod n = 1.
Print 2^? mod n = 1 otherwise.
You should replace x and n with specific numbers.
Print 2^? mod n = 1 otherwise.
You should replace x and n with specific numbers.
Sample Input
25
Sample Output
2^? mod 2 = 12^4 mod 5 = 1#include<stdio.h>int main(){int x,t,n;while(scanf("%d",&n)!=EOF){if(n==1||n%2==0)printf("2^? mod %d = 1\n",n);else{x=1;t=2;while(t%n!=1){x++;t=t*2%n;}printf("2^%d mod %d = 1\n",x,n);}}return 0;}题目中给出输入一个整数n,要求一个最小整数的x,使得2^x mod n=1;
根据模P乘法逆元:对于整数a、p如果存在整数b,满足a*b mod p=1则称b是a的模P乘法逆元。
a存在模P的乘法逆元的充要条件是gcd(a,p)=1,令a=2^x,b=1,p=n
则若存在x使用2^x mod n=1则gcd(2^x,n)=1
(1)因为要求x的值大于0。则2^x的因子中只有一个2,所以当n为偶数时gcd(2^x,n)=2k(k=1,2,3...),即此时不存在x使得2^x mod n=1。
(2)当n为奇数时gcd(2^x,n)=1,则必存在x使得2^x mod n=1。
(3)由于任何数模1的结果为0,所以当n=1时,无论x取何值,2^x mod n=0.
综合上述(1),(2),(3),当n的值为1或偶数时,不存在x使得2^x mod n=1,其它情况则必存在一x使得2^x mod n =1。
0 0
- HDU1395:2^x mod n = 1
- hdu1395-2^x mod n = 1
- hdu1395 2^x mod n = 1
- HDU1395---2^x mod n = 1
- hdu1395 2^x mod n = 1
- hdu1395 2^x mod n = 1
- ZOJ 1489 HDU1395 2^x mod n = 1 数学
- hdu1395 2^n mod n =1 简单数学题
- hdu1395 2^x mod n = 1(数论:快速幂取模+欧拉定理)
- HDU1395 ZOJ1489 2^x mod n = 1【暴力法+数论】
- 2^x mod n = 1
- ZOJ1489 2^x mod n = 1
- zoj1489-2^x mod n = 1
- 1073:2^x mod n = 1
- HDU 2^x mod n = 1
- HDU_1395 2^x mod n = 1
- 2^x mod n = 1
- hdoj1395 2^x mod n = 1
- I/O重定向和管道
- 解决JSP URL请求中文乱码问题方法
- hibernate入门级
- Servlet之四 Session的了解和学习
- 进程的重启脚本
- hdu1395 2^x mod n = 1
- hdu 2045 不容易系列之(3)―― LELE的RPG难题
- 苹果与虫子
- java中的数组(三)
- Lua调用C函数
- bash的配置文件
- const限定符
- CodeForces 55A. Flea travel
- FOJ2082 过路费