24小时热门版块排行榜    

查看: 641  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料专硕306英一数二 +8 z1z2z3879 2026-03-16 10/500 2026-03-18 00:01 by 星空星月
[考研] 293求调剂 +7 zjl的号 2026-03-16 12/600 2026-03-17 18:22 by 重科小霸王
[考研] 0703化学336分求调剂 +4 zbzihdhd 2026-03-15 5/250 2026-03-17 17:33 by ruiyingmiao
[考研] 材料工程专硕调剂 +5 204818@lcx 2026-03-17 5/250 2026-03-17 17:27 by Little-xue
[硕博家园] 湖北工业大学 生命科学与健康学院-课题组招收2026级食品/生物方向硕士 +3 1喜春8 2026-03-17 5/250 2026-03-17 17:18 by ber川cool子
[考研] 材料专硕326求调剂 +6 墨煜姒莘 2026-03-15 7/350 2026-03-17 17:10 by ruiyingmiao
[考研] 293求调剂 +6 世界首富 2026-03-11 6/300 2026-03-17 17:04 by ruiyingmiao
[考研] 271求调剂 +12 生如夏花… 2026-03-11 14/700 2026-03-17 10:56 by lovewei0727
[考研] 考研调剂 +3 淇ya_~ 2026-03-17 5/250 2026-03-17 09:25 by Winj1e
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 材料工程327求调剂 +3 xiaohe12w 2026-03-11 3/150 2026-03-14 20:20 by ms629
[考研] 材料080500调剂求收留 +3 一颗meteor 2026-03-13 3/150 2026-03-14 10:54 by peike
[考研] 材料与化工(0856)304求B区调剂 +6 邱gl 2026-03-12 7/350 2026-03-13 23:24 by 邱gl
[考研] 一志愿中科院,化学方向,295求调剂 +4 一氧二氮 2026-03-11 4/200 2026-03-13 22:35 by JourneyLucky
[考研] 336求调剂 +6 Iuruoh 2026-03-11 6/300 2026-03-13 22:06 by JourneyLucky
[考研] 考研调剂 +4 芬达46 2026-03-12 4/200 2026-03-13 16:04 by ruiyingmiao
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 290求调剂 +7 ADT 2026-03-12 7/350 2026-03-13 15:17 by JourneyLucky
信息提示
请填处理意见