24小时热门版块排行榜    

查看: 640  |  回复: 1

zyj8119

木虫 (著名写手)

[交流] 【转帖】素数测试(蒙特卡罗算法) 已有1人参与

CODE:
//素数测试的蒙特卡罗算法
/*
使用素数判定必要条件的费马小定理及二次探测定理
*/

#include
#include
#include "utils.cpp"
#include "random.hpp"

void power(unsigned int a,unsigned int p,unsigned int n,unsigned int &result,bool &composite)
{
    unsigned int x;
    if(p==0)
        result=1;
    else{
        power(a,p/2,n,x,composite);    //递归计算
        result=mod(x*x,n);
        if((result==1) &&(x!=1) && (x!=n-1))  //x^2=1(mod n) x!=1 && x!=n-1,则n为合数
            composite=true;
        if((p%2)==1)
            result=(result*a)%n;
    }
}

bool Prime(unsigned int n)
{// 素数测试的蒙特卡罗算法
   RandomNumber rnd;
   unsigned int a, result;
   bool composite=false;
   a=rnd.Random(n-3)+2;
   power(a,n-1,n,result,composite);
   if (composite||(result!=1))
       return false;
   else
       return true;
}

bool PrimeMC(unsigned int n,unsigned int k){//分析素数的过程
    RandomNumber rnd;
    unsigned int a,result;
    bool composite=false;
    for(unsigned int i=1;i<=k;i++){
        a=rnd.Random(n-3)+2; //a<-[2:n-2]
        power(a,n-1,n,result,composite);
        if(composite || (result!=1))
            return false;
    }
    return true;
}

int main(){
    char *addr="gdgzzch.blog.163.com";
    printf("本程序来自:%s\n",addr);
    FILE *fp=fopen("prime_input.txt","r");//输入流文件
    if(fp==NULL){
        printf("输入文件不存在!\n");
    }
    int num;    //测试的素数个数
    fscanf(fp,"%d",&num);
    int n;
    bool isprime;
    for(int i=1;i<=num;i++){
        fscanf(fp,"%d",&n);
        isprime=PrimeMC(n,6);
        printf("%d: ",n);
        if(isprime)
            printf("素数\n");
        else
            printf("合数\n");
    }
    return 1;
}

[ Last edited by zyj8119 on 2010-9-17 at 10:02 ]
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

好好学习,天天向上。
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xgsheng

金虫 (初入文坛)

ustc
2楼2011-11-07 15:48:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zyj8119 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085601材料工程专硕求调剂 +5 慕寒mio 2026-03-16 5/250 2026-03-17 21:31 by hmn_wj
[考研] 070300化学319求调剂 +4 锦鲤0909 2026-03-17 4/200 2026-03-17 18:21 by 重科小霸王
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 308求调剂 +4 是Lupa啊 2026-03-16 4/200 2026-03-17 17:12 by ruiyingmiao
[考研] 274求调剂0856材料化工 +13 z2839474511 2026-03-11 14/700 2026-03-17 16:51 by share_joy
[考研] 085600材料与化工求调剂 +5 绪幸与子 2026-03-17 5/250 2026-03-17 16:40 by laoshidan
[考研] 275求调剂 +4 太阳花天天开心 2026-03-16 4/200 2026-03-17 10:53 by 功夫疯狂
[考研] 材料与化工304求B区调剂 +7 邱gl 2026-03-11 8/400 2026-03-17 09:36 by 努力学习赚彩礼
[考研] 一志愿,福州大学材料专硕339分求调剂 +3 木子momo青争 2026-03-15 3/150 2026-03-17 07:52 by laoshidan
[考研] 286求调剂 +3 lemonzzn 2026-03-16 5/250 2026-03-16 20:43 by lemonzzn
[考研] 环境工程调剂 +6 大可digkids 2026-03-16 6/300 2026-03-16 17:16 by barlinike
[考研] 304求调剂 +5 素年祭语 2026-03-15 5/250 2026-03-16 17:00 by 我的船我的海
[考研] 0703化学调剂 290分有科研经历,论文在投 +7 腻腻gk 2026-03-14 7/350 2026-03-16 10:12 by houyaoxu
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考博] 东华理工大学化材专业26届硕士博士申请 +6 zlingli 2026-03-13 6/300 2026-03-15 20:00 by ryzcf
[考研] 22408总分284求调剂 +3 InAspic 2026-03-13 3/150 2026-03-15 11:10 by zhq0425
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 290求调剂 +9 ADT 2026-03-11 9/450 2026-03-13 21:55 by JourneyLucky
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[考研] 310求调剂 +3 【上上签】 2026-03-11 3/150 2026-03-13 16:16 by JourneyLucky
信息提示
请填处理意见