美文网首页
素数筛选

素数筛选

作者: 小码弟 | 来源:发表于2019-04-15 20:38 被阅读0次

今天在面试时被问到了一个问题:求不大于n的最大素数,当时只想出暴力解法,回来查资料找到了正确的求解方法。

素数筛法是这样的:
1. 开一个大的bool型数组prime[],大小就是n+1就可以了.先把所有的下标为奇数的标为true,下标为偶数的标为false.

vector<bool> prime(n+1, true);
for(int i=0; i<n+1; ++i)
  if(i%2 == 0)
    prime[i] = false;
  1. 然后:
      for(int i=3; i<=sqrt(n); i+=2)
      {   if(prime[i]) 
          for( j=i+i; j<=n; j+=i ) prime[j]=false;
      }

3.最后输出bool数组中的值为true的单元的下标,就是所求的n以内的素数了。

背后的原理是:当i是素数的时候,i的所有的倍数必然是合数。如果i已经被判断不是质数了,那么再找到i后面的质数来把这个质
数的倍数筛掉。

相关文章

  • Algorithm

    素数筛选

  • 素数筛选

    今天在面试时被问到了一个问题:求不大于n的最大素数,当时只想出暴力解法,回来查资料找到了正确的求解方法。 素数筛法...

  • 筛选素数/筛选质数

  • 区间素数线性筛选

    区间素数线性筛选 假设应用场景为求一个区间长度远小于右端点的所有素数,该区间为 。如若使用朴素素数线性筛选,则需...

  • 素数线性筛选

    素数线性筛选 素数的定义是除了1和自身能被整除外,没有其他数能被它整除。除此之外,1既不是素数,也不是合数。因此,...

  • 素数算法

    寻找素数的算法有很多,最著名应是筛选法,以下是笔者用JavaScript编写的一个找素数的函数,借鉴了各种找素数的...

  • 筛选法求素数

  • RSA加密解密算法—数论基础

    本章涉及知识点1、素数的定义2、寻找素数算法—短除法3、寻找素数算法—筛选法4、互质关系5、欧拉函数的证明6、欧拉...

  • 筛选N以内的素数

    1.题目描述用简单素数筛选法求N以内的素数。 2.格式与样例:输入格式N输出格式2~N的素数输入样例100输出样例...

  • 线性筛选法求素数

网友评论

      本文标题:素数筛选

      本文链接:https://www.haomeiwen.com/subject/olnpwqtx.html