题目描述
Neko猫是一个很喜欢玩数字游戏的会说话的肥猫,经常会想到很多很好玩的数字游戏,有一天,它想到一个叫做素数间隙的游戏。据Neko猫的定义,素数间隙是两个相邻素数p和q组成的开区间[p, q),所以素数间隙的长度就是q-p。
例如7和11在素数表里是两个相邻的素数,所以7和11的素数间隙的长度为11-7,为4。
现在Neko猫会给你很多个正整数K(1<K≤1299710),让你能立刻求出包含数字K的素数间隙的长度。为方便起见,如果K是素数,则输出0。
输入
输入包含T组数据(1≤T≤1000),每组测试数据占一行,是一个正整数K(1<K≤1299710)。
输出
输出T行,每行一个非负数,这个非负数是包含输入数字K的素数间隙的长度,不应有其他字符出现在输出中。
示例输入
10 11 27 2 492170
示例输出
4 0 6 0 114
此题用到素数筛
#include <stdio.h>
#include <string.h>
#include <math.h>
int prime[1299710],b[1299710],a[1299710];
bool mark[1299710];
int main()
{
int i,j,k,n,pos;
memset(prime,0,sizeof(prime));
memset(mark,false,sizeof(mark));
memset(a,0,sizeof(a));
k=1;
mark[0]=mark[1]=true;
for(i=2;i<=1299710;i++)
{
if(mark[i]==false)
{
prime[k++]=i;//把素数放进去
a[i]=-1;//并且是素数就标记为-1
for(j=2*i;j<=1299710;j+=i)
mark[j]=true;//筛掉素数的倍数
}
}
while(~scanf("%d",&n))
{
int p,q,sum,v;
v=n;
while(a[v]==0)
{
v++; //找比n大的素数
}
while(a[n]==0)
{
n--;//找比n小的素数
}
printf("%d\n",v-n);
}
return 0;
}