| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 683 人关注过本帖
标题:[分享]令(2^x)%n==1成立的最小x
只看楼主 加入收藏
–★–
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1512
专家分:0
注 册:2006-5-1
收藏
 问题点数:0 回复次数:8 
[分享]令(2^x)%n==1成立的最小x
/*
【题】对于给定的正整数n,找出一个最小的
自然数x,使下式得以成立 (2^x)%n==1
*/
#include<stdio.h>
int main()
{ unsigned int n,x,mod;
printf("n=");
scanf("%d",&n);
if(n<=1||n%2==0)//如果n是1或者偶数,则无解
{
fprintf(stderr,"no solution...\n");
return 1;
}
for(x=1,mod=2; ;x++,mod+=mod)
{
if(mod>n)mod-=n;
if(mod==1)break;
}
printf("x=%d\n",x);
return 0;
}

/*希望某求教于人的网友不要故弄玄虚,
搞什么支付金币才能观看他的帖子之类*/
搜索更多相关主题的帖子: 成立 分享 
2006-05-24 18:37
feng1256
Rank: 4
等 级:贵宾
威 望:14
帖 子:2899
专家分:0
注 册:2005-11-24
收藏
得分:0 

凑个热闹
[CODE]
#include "stdio.h"

int main()
{
int n,x=1,m=2;

printf("n=");
scanf("%d",&n);
if(n==1||n%2==0)
exit(-1);
for(;;m*=2,x++)
{
m=m%n;
if(m==1)
break;
}
printf("x=%d\n",x);

return 0;
}


[/CODE]


叁蓙大山:工謪、稅務、嗣發 抱歉:不回答女人的问题
2006-05-25 05:26
lxgaaa
Rank: 1
等 级:新手上路
帖 子:59
专家分:0
注 册:2006-5-17
收藏
得分:0 
for(x=1,mod=2; ;x++,mod+=mod)
这个不错,加法的效率比乘法高很多

天高任鸟飞,海阔任鱼翱
2006-05-25 09:22
–★–
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1512
专家分:0
注 册:2006-5-1
收藏
得分:0 
回复:(lxgaaa)for(x=1,mod=2; ;x++,mod+=mod)这个不...
以下是引用lxgaaa在2006-5-25 9:22:00的发言:
for(x=1,mod=2; ;x++,mod+=mod)
这个不错,加法的效率比乘法高很多

朋友,别忙着夸我,出个题目给你做做:
mod+=mod的理由是什么?


落霞与孤鹜齐飞,秋水共长天一色! 心有多大,路有多宽。三教九流,鸡鸣狗盗。兼收并蓄,海纳百川。
2006-05-25 16:20
feng1256
Rank: 4
等 级:贵宾
威 望:14
帖 子:2899
专家分:0
注 册:2005-11-24
收藏
得分:0 

–★– 你看三楼头像是黑的! 搞不好他这辈子再不来论坛了


叁蓙大山:工謪、稅務、嗣發 抱歉:不回答女人的问题
2006-05-25 16:23
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 

是在说我吗?我不知道怎么弄,不是我想搞啊


倚天照海花无数,流水高山心自知。
2006-05-26 18:50
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
教教我啊

倚天照海花无数,流水高山心自知。
2006-05-26 18:51
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 

版主:)看看我的吧.
#include<iostream.h>
#include<stdio.h>

int main()
{
#ifndef ONLINE_JUDGE
freopen ("abc.txt","r",stdin);
#endif
int i;
long s,n;
while(EOF!=(scanf("%ld",&n))&&n!=0)
{
if(n%2==0||n<2)
{
printf("2^? mod %ld = 1\n",n);
}
else
{
s=1;i=0;
while(1)
{
if(s<n)
{
s=s*2;
i++;
}
else
{
s=s-n;
}
if(s==1)
break;
}
printf("2^%d mod %ld = 1\n",i,n);
}
}
return(0);
}


倚天照海花无数,流水高山心自知。
2006-05-26 19:02
avlmo
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2006-5-26
收藏
得分:0 
看来我得先去学书去..看你们说的我都看不懂

衣服脱掉后,爱情就哭了.
2006-05-26 19:06
快速回复:[分享]令(2^x)%n==1成立的最小x
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016151 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved