c++素数筛选法

来源:爱站网时间:2019-10-02编辑:网友分享
C++中的素数筛选大家清楚吗?它是一种求取不超过自然数的方法,那么就让爱站技术频道小编带我们一起了解c++素数筛选法吧,希望对你了解这方面知识有所帮助。

C++中的素数筛选大家清楚吗?它是一种求取不超过自然数的方法,那么就让爱站技术频道小编带我们一起了解c++素数筛选法吧,希望对你了解这方面知识有所帮助。

素数(又称质数):指在大于一的自然数中,只能被1和它自身整除的自然数;

素数筛选法是指一种非常规的素数判定方法,比较高效率;

原理:任何数的整数倍必定不是素数,大于二的偶数必定不是素数。

我们以找出100以内的素数为例,利用原理,我们可以首先排除偶数是素数,然后进一步判断奇数

实现将偶数标记为0,素数标记为1;(也可以用一个bool数组将偶数标记为false,奇数标记为true)

下面是全部代码

#include <iostream>
#include <cmath>
#define MAX 100 
using namespace std;

int main()
{
      //设置标记,将偶数标记为0 
      int prime[MAX+1];
      for(int i=1;i<=MAX;i++)
      {
        if(i%2==0)
        {
          prime[i]=0;
        }
        else prime[i]=1;
      }
      
      for(int i=3;i<=sqrt(MAX);i++)
      {
        if(prime[i]==1)
        {
          for(int j=i+i;j<=MAX;j=j+i)
          {
              prime[j]=0;
          }
        }
      }    
      cout<<"2"<<" ";
      for(int i=3;i<=MAX;i++)
      {
        if(prime[i]==1)
        cout<<i<<" ";
      }
  return 0;  
} 

以上就是爱站技术频道小编介绍的c++素数筛选法,希望能够帮助到对此需要的你,我们在开发程序的时候都会遇到瓶颈,这个时候我们要越过去,才能更加强大。

上一篇:详解C++ 遍历二叉树实例介绍

下一篇:C++基础知识总结

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载