`
XiAoOMAn07
  • 浏览: 75678 次
  • 性别: Icon_minigender_1
  • 来自: 温州
社区版块
存档分类
最新评论

prime【】素数读取

阅读更多
求质数的文章: [原创]求质数(C语言描述) 【问题描述】:
试编写一个程序,找出2->N之间的所有质数。希望用尽可能快的方法实现。
【问题分析】:
这个问题可以有两种解法:一种是用“筛子法”,另一种是从2->N检查,找出质数。
先来简单介绍一下“筛法”,求2~20的质数,它的做法是先把2~20这些数一字排开:
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
先取出数组中最小的数,是2,则判断2是质数,把后面2的倍数全部删掉。
2 | 3 5 7 9 11 13 15 17 19
接下来的最小数是3,取出,再删掉3的倍数
2 3 | 5 7 11 13 17 19
一直这样下去,直到结束。
筛法求质数的问题时,非质数的数据有很多是重复的。例如,如果有一个数3×7×17×23,那么在删除3的倍数时会删到它,删7、17、23时同样也会删到它。有一种“线性筛法”,可以安排删除的次序,使得每一个非质数都只被删除一次。从而提高效率。因为“筛法”不是我要介绍的重点,所以就不介绍了。
现在我来介绍第二种方法。用这种方法,最先想到的就是让从2~N逐一检查。如果是就显示出来,如果不是,就检查下一个。这是正确的做法,但效率却不高。当然,2是质数,那么2的倍数就不是质数,如果令i从2到N,就很冤枉地测试了4、6、8……这些数?所以第一点改建就是只测试2与所有的奇数就足够了。同理,3是质数,但6、9、12……这些3的倍数却不是,因此,如果能够把2与3的倍数跳过去而不测试,任意连续的6个数中,就只会测试2个而已。以6n,6n+1,6n+2,6n+3,6n+4,6n+5为例,6n,6n+2,6n+4是偶数,又6n+3是3的倍数,所以如果2与3的倍数都不理会,只要测试的数就只留下6n+1和6n+5而已了,因而工作量只是前面想法的2/6=1/3,应该用这个方法编程。
还有个问题,就是如果判断一个数i是否为素数。按素数的定义,也就是只有1与本身可以整除,所以可以用2~i-1去除i,如果都除不尽,i就是素数。观点对,但却与上一点一样的笨拙。当i>2时,有哪一个数可以被i-1除尽的?没有,为什么?如果i不是质数,那么i=a×b,此地a与b既不是i又不是1;正因为a>1,a至少为2,因此b最多也是i/2而已,去除i的数用不着是2~i-1,而用2~i/2就可以了。不但如此,因为i=a×b,a与b不能大于sqrt(i),为什么呢?如果a>sqrt(i),b>sqrt(i),于是a×b>sqrt(i)*sqrt(i)=i,因此就都不能整除i了。如果i不是质数,它的因子最大就是sqrt(i);换言之,用2~sqrt(i)去检验就行了。
但是,用2~sqrt(i)去检验也是浪费。就像前面一样,2除不尽,2的倍数也除不尽;同理,3除不尽,3的倍数也除不尽……最理想的方法就是用质数去除i。
但问题是这些素数从何而来?这比较简单,可以准备一个数组prime[],用来存放找到的素数,一开始它里面有2、3、5。检查的时候,就用prime[]中小于sqrt(i)的数去除i即可,如果都除不尽,i就是素数,把它放如prime[]中,因此prime[]中的素数会越来越多,直到满足个数为止!
不妨用这段说明来编写这个程序,但是程序设计的时候会有两个小问题:
1.如果只检查6n+1和6n+5?不难发现,它们的距离是4、2、4、2……所以,可以先定义一个变量gab=4,然后gab=6-gab;
2.比较是不能用sqrt(i),因为它不精确。举个例子,i=121,在数学上,sqrt(i)自然是11,但计算机里的结果可能是10.9999999,于是去除的数就是2、3、5、7,而不含11,因此121就变成质数了。解决这个问题的方法很简单,不要用开方,用平方即可。例如,如果p*p<=i,则就用p去除i。而且它的效率比开方高。

【程序清单】:
#include <stdio.h>

int creat_prime(int prime[],int n,int total)
{
        register        int        i;
        register        int        j;
        register        int        gab=2;
        register        int        count;
        for(i=7;i<=n;i+=gab)
        {
                count=1;
                gab=6-gab;
                for(j=0;prime[j]*prime[j]<=i;j++)
                {
                        if(i%prime[j]==0)
                        {
                                count=0;
                                break;
                        }
                }
                if(count)
                {
                        prime[total]=i;
                        total++;
                }
        }

        return total;
}

int main(void)
{
        int        prime[30000]={2,3,5};
        int        total=3;        //找到素数的个数
        int        i;
        int        n=200000;        //要查找的范围(>=6)

        total=creat_prime(prime,n,total);
        for(i=0;i<total;i++)
        {
                printf("%d ",prime[i]);
                if(i && !(i%10))
                        putchar('\n');
        }
        putchar('\n');
}

分享到:
评论

相关推荐

    POJ3292-Semi-prime H-numbers

    这个题目主要涉及数论和算法设计,特别是关于半素数(Semi-prime)的概念以及H-Numbers的相关计算。 【描述】"北大POJ3292-Semi-prime H-numbers 解题报告+AC代码"表明这是一个已经解决的编程问题,包含了解题思路...

    素数环的c++实现

    素数环,又称为“质数环”,是指一组正整数排列成环状,其中任意相邻两个数之和都是一个质数。这个问题源于数论中的组合构造问题,它要求找到这样的一个环,使得环上的每个元素都是正整数,并且满足特定的条件。在给...

    素数、二维数组键入、奇数存入二进制、读取文件数据

    出2100的所有素数,将求出的素数分别送到文文件 prime.txt和二进制文件prime.dat中。送到文本文件中的结果,要求以表格形式输出,每一行输出5个素数,每一个数占用10个字符宽度。 用文本编辑器产生一个包含若实数的...

    输出任意两个整数之间的所有素数

    - **if语句**:在`prime`方法中使用了`if`语句来判断一个数是否为素数。例如:`if (j &gt; m / 2 && m != 1) {...}`。 ### 4. 方法定义 #### 4.1 定义方法 - `static int prime(int m)` 定义了一个静态方法`prime`,...

    设计一个文件来保存并显示1000以内的素数

    文件中的每个素数后面加上换行符('\n'),以便于在读取时每行显示一个素数。完成写入后,可以使用`file.close()`关闭文件,但推荐使用`with`语句,因为它会自动处理文件关闭,避免资源泄露。 要显示这些素数,我们...

    ZHISHU.rar_Prime number ASM_is prime asm

    标题 "ZHISHU.rar_Prime number ASM_is prime asm" 暗示了这是一个关于使用汇编语言实现素数判断的程序。在这个项目中,我们主要关注如何在汇编语言环境下编写代码来找出并打印出一个指定范围内(0-65535)的所有...

    计算n以内的所有素数并写入文件

    我们可以使用之前定义的`is_prime`函数,对每个数字进行检查,如果它是素数,则将其添加到结果列表中: ```python def generate_primes(n): primes = [] for num in range(2, n + 1): if is_prime(num): primes...

    c#素数判断

    在Main方法中,首先读取用户输入的数字a,然后调用prime方法判断a是否为素数。如果是,则输出"{0}是一个素数",否则输出"{0}不是素数"。 需要注意的是,以上代码只是一个简单的示例,实际上判断素数有多种方法,...

    判断一个数 m 是否素数的方法

    `读取用户输入的数。 - **计算试除范围**:利用`sqrt(m)`计算\(\sqrt{m}\)。 - **试除循环**:`for (i = 2; i ; i++)` 循环从2开始,逐个测试是否可以整除\(m\)。 - 如果可以整除,使用`break;`立即退出循环。 - **...

    对质数进行枚举,这是算法类问题的解答

    **质数**(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的数。质数在数学和计算机科学中具有重要的地位,尤其是在密码学领域。 **质数枚举**是指通过一定的算法找出一定范围内的所有质数...

    结构化程序设计求素数

    结合这两个部分,程序可能包含一个主函数,先获取用户输入的数字范围(比如1到N),计算出其中的所有素数,然后读取学生信息,筛选出分数高于一定值的学生。整个程序结构清晰,易于理解和维护,符合结构化程序设计的...

    判断一个素数能被几个9整除

    1. **素数定义**:素数(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的数。例如2、3、5、7等。 2. **被整除的概念**:如果一个数A可以被另一个数B整除,意味着A除以B的结果为整数且没有...

    编写Python代码,实现寻找反素数的功能

    代码使用一个函数is_prime,判断一个数是否是素数,使用试除法 代码使用一个函数is_palindrome,判断一个数是否是回文数,使用字符串反转的方法 代码使用一个函数is_reversible_prime,判断一个数是否是反素数,使用...

    求1000以内的质数C++程序

    - **质数**(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的数。 - 例如,2、3、5、7、11等都是质数。 #### 2. 特殊情况 - 1既不是质数也不是合数。 - 2是最小的质数,也是唯一的偶数...

    整数分解成质数

    ### 整数分解成质数 #### 背景与问题描述 在计算机科学与数学领域,整数分解是一项基本而重要的任务。特别是在密码学、数论等领域有着广泛的应用。本篇文章将通过一个具体的示例——如何使用Java编程语言来实现一...

    判断一个数是不是素数

    - **定义**:素数(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。 - **背景**:素数在密码学、随机数生成等领域具有重要的应用价值。因此,设计高效且准确的素数检测算法成为了...

    C语言-输入一个数判断是否为素数

    在这个问题中,我们可以定义一个函数,例如`is_prime()`,来检查给定的数值是否为素数。 ```c #include #include // 函数定义:判断是否为素数 bool is_prime(int num) { if (num ) { return false; // 1不是...

    判断素数题目,分函数;

    - **定义**:素数(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。 - **判断方法**: - 给定一个整数`n`,可以通过试除法来判断它是否为素数。 - 试除法的基本思路是检查`n`...

    回文素数c语言 详解.zip

    在这个程序中,`is_prime`函数用于判断素数,`is_palindrome`函数用于判断回文。`main`函数中,我们读取用户输入的整数,然后调用这两个函数进行判断,并输出结果。 这个程序仅作为示例,实际应用中可能需要考虑...

    不同存储方式上求素数的

    - 逐个读取文件中的数字,判断是否为素数。 - 将素数按照指定格式输出。 2. **特点**: - 适用于处理大规模数据。 - 可以有效利用磁盘空间。 3. **适用场景**: - 当数据量非常大,无法全部加载到内存时。 ###...

Global site tag (gtag.js) - Google Analytics