快速求指定区间内素数数量(素数筛+前缀)

#include<bits/stdc++.h>
using namespace std;

int f[1000001];
bool vis[1000001];

void shai(int n)
{
    f[1]=0;
    vis[1]=true;
    for(int i=2;i<=n;i++)
    {
        if(vis[i]==false) //在筛里进行前缀和
        {
            f[i]=f[i-1]+1;//前缀和计算
            for(int j=i+i;j<=n;j=j+i)
            {
                vis[j]=true;//标记操作
            }
        }
        else f[i]=f[i-1];//前缀和转移
    }
}

int main()
{
    int n;
    scanf("%d"&n);
    shai(n);
    int l,r;
    scanf("%d%d",&l,&r);
    int y=f[r]-f[l-1];
    cout<<y<<endl;
    return 0;
}

 


版权声明:本文为qq_43256272原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。