| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 683 人关注过本帖
标题:[分享]令(2^x)%n==1成立的最小x
取消只看楼主 加入收藏
–★–
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1512
专家分:0
注 册:2006-5-1
收藏
 问题点数:0 回复次数:1 
[分享]令(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
–★–
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
快速回复:[分享]令(2^x)%n==1成立的最小x
数据加载中...
 
   



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

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