热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何提高筛选法求大范围素数的效率

筛选法求素数有一个很通用的算法,就是在遍例该集合时,比方检验一个数N是否素数,用N除以2-N的开方,只要有一个能整除,就说明N不是素数。另外这道题要求用数组来计算。谓筛选法指的是埃拉托色尼(Eratosthenes)筛法。他是古希腊的著名数学家。

素数的定义:只能被1和它自己整除的自然数称为素数,特别规定1不属于素数。

根据素数的定义,很明显,如果一个数是素数<==>它的因子只包含1和它本身。因此可以根据判别某个数的因子的方法来判断其是否是素数。

int isprime(int n)
{
    int i;
    for(i=2;i<=(int)sqrt((double)n);i++)
    {
        if(n%i==0)    //如果n存在其它因子,则必定不是素数
         {
            return 0;
        }
    }
    return 1;
}

但是如果要求求出1000000以内的所有素数,上面的方法效率就很低,因此通常采用筛选法去求素数。筛选法:对于一个数n,如果是素数,那么2*n,3*n,4*n,必定不是素数。

bool isprime[1000001];
int prime[80000];
int num=0;
void getPrime()     //用筛选法求算素数
{
    int i,j;
    for(i=0;i<1000001;i++)
    {
        isprime[i]=true;
    }
    for(i=2;i<=1000;i++)        //如果isprime[i]==true,即i是素数,那么i,2*i,3*i必定不是素数
     {
        for(j=i+i;j<=1000000;j+=i)
        {
            if(isprime[i]==true)
                isprime[j]=false;
        }
    }
    for(i=2;i<1000001;i++)
    {
        if(isprime[i]==true)
        {
            prime[num++]=i;
        }
    }
}

筛选法求素数有一个很通用的算法,就是在遍例该集合时,比方检验一个数N是否素数,用N除以2-N的开方,只要有一个能整除,就说明N不是素数。另外这道题要求用数组来计算。

所谓"筛选法"指的是"埃拉托色尼(Eratosthenes)筛法"。他是古希腊的著名数学家。他采取的方法是,在一张纸上写上1到100全部整数,然后逐个判断它们是否是素数,找出一个非素数,就把它挖掉,最后剩下的就是素数。

具体做法如下:

  1. 先将1挖掉(因为1不是素数)。
  2. 用2去除它后面的各个数,把能被2整除的数挖掉,即把2的倍数挖掉。
  3. 用3去除它后面的各数,把3的倍数挖掉。
  4. 分别用4、5…各数作为除数去除这些数以后的各数。这个过程一直进行到在除数后面的数已全被挖掉为止。例如找1~50的素数,要一直进行到除数为47为止(事实上,可以简化,如果需要找1~n范围内素数表,只需进行到除数为n^2(根号n),取其整数即可。例如对1~50,只需进行到将50^2作为除数即可。)

如上算法可表示为:

  1. 挖去1;
  2. 用刚才被挖去的数的下一个数p去除p后面各数,把p的倍数挖掉;
  3. 检查p是否小于n^2的整数部分(如果n=1000, 则检查p<31?),如果是,则返回(2)继续执行,否则就结束;
  4. 纸上剩下的数就是素数。
#include 
#include 
int main(void)
{
    int i;
    int j;
    int a[101];                // 为直观表示,各元素与下标对应,0号元素不用
    for (i = 1; i <= 100; i++) // 数组各元素赋值
        a[i] = i;
    for (i = 2; i 												

本文地址:http://www.nowamagic.net/librarys/veda/detail/1350,欢迎访问原出处。


推荐阅读
  • 本文详细介绍如何在华为手机上安装鸿蒙3.0系统及下载兼容鸿蒙系统的新版应用,包括前期准备、升级途径以及应用下载的具体步骤。 ... [详细]
  • 扎根中国十年,这家海外互联网巨头的创新视频广告策略
    在过去十年间,许多海外互联网企业纷纷在中国设立分支机构,旨在挖掘这一市场的巨大潜力。然而,其中一些企业的布局却有着不同的考量。 ... [详细]
  • 本文详细介绍了在作业帮应用中如何启用护眼模式,调整屏幕颜色为浅黄色,并关闭不必要的通知音,以提升用户的使用体验。 ... [详细]
  • 本文对唐代诗人元稹的作品《和乐天重题别东楼》进行了深入的解析与赏析,通过对其原文的翻译及艺术特色的探讨,揭示了诗作中蕴含的深刻情感与文化价值。 ... [详细]
  • 深入理解TCP头部结构
    本文详细介绍了TCP头部的各个字段及其功能,包括源端口、目标端口、序列号、确认号等关键字段,以及TCP头部的大小、标志位、窗口大小、校验和等辅助信息。通过解析实际的TCP头部示例,帮助读者更好地理解TCP协议的工作原理。 ... [详细]
  • LoadRunner中的IP欺骗配置与实践
    为了确保服务器能够有效地区分不同的用户请求,避免多人使用同一IP地址造成的访问限制,可以通过配置IP欺骗来解决这一问题。本文将详细介绍IP欺骗的工作原理及其在LoadRunner中的具体配置步骤。 ... [详细]
  • 本文探讨了Java编程语言中常用的两个比较操作符==和equals方法的区别及其应用场景。通过具体示例分析,帮助开发者更好地理解和使用这两个概念,特别是在处理基本数据类型和引用数据类型的比较时。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 探讨了在移动设备上使用contentEditable属性时遇到的布局问题,并提供了解决方案。 ... [详细]
  • 本文详细介绍了在PHP中如何获取和处理HTTP头部信息,包括通过cURL获取请求头信息、使用header函数发送响应头以及获取客户端HTTP头部的方法。同时,还探讨了PHP中$_SERVER变量的使用,以获取客户端和服务器的相关信息。 ... [详细]
  • 本文概述了在GNU/Linux系统中,动态库在链接和运行阶段的搜索路径及其指定方法,包括通过编译时参数、环境变量及系统配置文件等方式来控制动态库的查找路径。 ... [详细]
  • 本文介绍了如何通过设置特定属性来取消小程序中 Navigator 组件的默认点击效果,提高用户体验。 ... [详细]
  • 本文详细介绍了在MyBatis框架中如何通过#和$两种方式来传递SQL查询参数。使用#方式可以提高执行效率,而使用$则有助于在复杂SQL语句中更好地查看日志。此外,文章还探讨了不同场景下的参数传递方法,包括实体对象、基本数据类型以及混合参数的使用。 ... [详细]
  • 探讨在使用 PHP 函数 array_combine 时遇到的重复键名问题,并提出解决方案以确保所有数据都能被正确显示。 ... [详细]
  • 本文详细介绍了如何使用Rufus工具制作一个兼容UEFI启动模式的Windows Server 2008 R2安装U盘,包括必要的软件和步骤。 ... [详细]
author-avatar
katsulyl_266
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有