素数筛 poj 3518

Posted HelloWorld!--By-MJY

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了素数筛 poj 3518相关的知识,希望对你有一定的参考价值。

给你一个n

求包括n的一个非素数区间有多长 +1输出

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<vector>
#include<math.h>

using namespace std;
#define MAXN 1302000
bool pri[MAXN];

int main()
{
    memset(pri,0,sizeof(pri));

    for(int i=2;i<=1141;i++)
    {
        if(!pri[i])
            for(int j=i*i;j<=MAXN;j=j+i)
                pri[j]=1;
    }
    int n;

    while(scanf("%d",&n)!=EOF&&n)
    {
        int st=n,en=n;
        while(pri[st]==1)
            st--;
        while(pri[en]==1)
            en++;
        printf("%d\n",en-st);
    }

    return 0;
}

 

以上是关于素数筛 poj 3518的主要内容,如果未能解决你的问题,请参考以下文章

POJ 3518 Prime Gap(素数题)

poj2262 Goldbach's Conjecture——筛素数

poj2739尺取法+素数筛

poj 2689 区间素数筛

POJ-2689-Prime Distance(素数区间筛法)

Semi-prime H-numbers POJ 3292(素数筛)