码迷,mamicode.com
首页 > 其他好文 > 详细

素数筛 poj 3518

时间:2016-12-13 18:40:51      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:bsp   scanf   sizeof   using   i++   name   ++   while   max   

给你一个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

标签:bsp   scanf   sizeof   using   i++   name   ++   while   max   

原文地址:http://www.cnblogs.com/cherryMJY/p/6170921.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!