13110581088注销
素数间隙
Time Limit: 1000MS Memory limit: 262144K
题目描述
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
提示
来源
青岛理工交流赛
示例程序
算法分析: 素数筛 筛好范围的素数标记下。 然后判断一下,f[n]是不是素数,如果是就输出0,否则往标记数组两边走,直到找到两端的素数,
把它们的下标相减输出就行了,1Y !
#include <iostream> #include <string> #include <stdio.h> #include <string.h> #include <algorithm> using namespace std; int f[1300000]; void sushushai() { memset(f, 0, sizeof(f)); f[1]=1; int i, j; i=2; while(i<=10000) { for(j=i*2; j<=1299710; j+=i) { f[j]=1; //不是素数 } i++; while(f[i]==1) { i++; } } } int main() { sushushai(); int n; int dd, j; while(cin>>n) { if(f[n]==0 ) //如果本身就是素数 { cout<<"0 "; } else { j=n-1; dd=n+1; while( f[j]==1 ) { j--; } while( f[dd]==1 ) { dd++; } cout<<dd-j<<endl; } } return 0; }