| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 923 人关注过本帖
标题:可测定不超过1,000,000的素数判定程序
只看楼主 加入收藏
silentfrog
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-12-24
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
可测定不超过1,000,000的素数判定程序
定理:设n是一个正整数,如果对所有的素数p≤根号N,都有płn,则n一定是素数。
 注:古希腊数学家埃拉托斯散(Eratosthenes,公元前275—公元前194)发明了求比某给定数小的素数的筛法技巧。
 方法如下:
 对于任意给定的正整数N,要求出所有不超过N的素数。我们列出N个整数,从中删除小于等于根号N的所有素数p1,…,pk的倍数。然后依次删除,
   p1的倍数:2p1,…, p1
                         ……
     pk的倍数:2pk,…, pk
 余下的整数(不包括1)就是所要求的不超过N的素数。


求大神帮忙
搜索更多相关主题的帖子: 发明 数学家 古希腊 正整数 
2011-12-24 16:52
我是菜鸟C
Rank: 4
等 级:业余侠客
帖 子:74
专家分:200
注 册:2011-3-27
收藏
得分:10 
#include <iostream>
using namespace std;
int SQRT(int a)    //用来求开方根,若用c写的话可直接用math.h头文件 然后用sqrt求解。
{
    int x,y;
    cin>>a;
    if(a<0)
    {
         cout<<"负数没有平方根"<<endl;
         return 0;
    }
    else
    {
        x=1;
        y=(x+a/x)/2;
        while(x!=y)
        {
            x=y;
              y=(x+a/x)/2;
        }
            return a;
     }

}

bool func(int a)   //用来判断素数
{
    int count=0;   
    int i=1;
    while(i<=a){
        if(a%i==0)
            count++;
            i++;
    }
    if(count==2)
        return true;
    else
        return false;
}
int main(){
    int N;
    cout<<"请输入要测定的数(不大于1000000):"<<endl;
    cin>>N;
    if(N>1000000){
        cout<<"error!"<<endl;
        return 0;
    }
    int num = N-1;
    for(int j=1;j<=SQRT(N);j++){   
        if(func(j)){
                for(int k = 1;k<N/j;k++)
                    num--;
        }
    }
    cout<<"素数的个数为:"<<num<<endl;
    return 0;
}
2011-12-25 22:35
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
收藏
得分:0 
是个挺基础的问题。建议楼主自己写写盾。

另外如果只是想求代码,在坛子里搜一下也有的是。
2011-12-28 01:43
快速回复:可测定不超过1,000,000的素数判定程序
数据加载中...
 
   



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

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