24小时热门版块排行榜    

Znn3bq.jpeg
查看: 660  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085801电气专硕272求调剂 +20 电气李 2026-04-13 22/1100 2026-04-20 00:15 by Equinoxhua
[考研] 求计算机方向调剂 +3 Toffee2 2026-04-16 6/300 2026-04-19 22:37 by ll叶
[考博] 湖南大学刘巧玲课题组2026年第二批次博士研究生招生信息 +3 南风观火 2026-04-18 3/150 2026-04-19 21:44 by 淡雅人生27
[考研] 26药学专硕105500求调剂 +7 喽哈加油 2026-04-13 8/400 2026-04-19 20:21 by Equinoxhua
[考研] 289 分105500药学专硕求调剂(找B区学校) +5 白云123456789 2026-04-13 5/250 2026-04-19 18:12 by Equinoxhua
[考研] 304求调剂 +8 castLight 2026-04-16 8/400 2026-04-19 17:14 by 中豫男
[论文投稿] 有没有接收比较快的sci期刊呀,最好在一个月之内的,研三孩子求毕业 20+4 之护着 2026-04-16 6/300 2026-04-19 13:00 by Aaron_zyn
[考研] 307中医考研调剂 +9 于以采蘩 2026-04-14 9/450 2026-04-19 08:41 by 烟雨流涯
[考研] 一志愿沪9,326求生物学调剂 +12 刘墨墨 2026-04-13 12/600 2026-04-18 23:31 by 路病情
[考研] 320求调剂 +5 深郊akm 2026-04-17 5/250 2026-04-18 19:52 by 王珺璞
[考研] 297,工科调剂? +5 河南农业大学-能 2026-04-14 5/250 2026-04-18 15:17 by Equinoxhua
[考研] 22408 312求调剂 +24 门路摸摸 2026-04-14 26/1300 2026-04-18 13:04 by wunaiy88
[考研] 收到复试调剂但是去不了 +8 小蜗牛* 2026-04-16 8/400 2026-04-18 11:15 by zixin2025
[考研] 急需调剂 +9 绝不放弃22 2026-04-15 10/500 2026-04-18 08:09 by chixmc
[考博] 申博/考博 +3 啃面包的小书虫 2026-04-17 4/200 2026-04-17 23:54 by 阳阳阳^_^
[考研] 一志愿华中农业071010,320求调剂 +17 困困困困坤坤 2026-04-14 19/950 2026-04-17 20:08 by 关一盏灯cd
[考研] 一志愿沪9,生物学326求调剂 +9 刘墨墨 2026-04-15 9/450 2026-04-16 17:14 by 崔崔崔cccc
[考研] 药学求调剂 +14 喽哈加油 2026-04-14 16/800 2026-04-16 10:15 by beilsong20
[考研] 求调剂学校 +14 不会吃肉 2026-04-13 16/800 2026-04-15 21:59 by noqvsozv
[考研] 085600材料与化工329分求调剂 +24 叶zilin 2026-04-13 25/1250 2026-04-14 09:20 by 试管破裂
信息提示
请填处理意见