求出范围内所有素数
Description
给出整数a,b,求出区间[a,b]内的所有素数。
Input
有多组测试数据。输入的第一行是整数T(0<T<=1000),表示测试数据的组数。每一组测试数据只有一行,分别为整数a和b,两数之间有一个空格。该行没有其它多余的符号。0<a<b<2^16。
Output
对应每组输入,输出一行[a,b]区间内所有的素数,每个数后应有一个空格,如果[a,b]区间内没有素数,则该行为空行。该行不能有其它多余的符号。
Sample Input
2
1 100
50 100
Sample Output
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97
53 59 61 67 71 73 79 83 89 97
Hint
可以考虑筛法求素数。
Source
#include <cstdio>
#include <cstring>
const int max_n = 70000;
int main()
{
int flag[max_n];
memset(flag, 0, sizeof(flag));
flag[1] = 1;
int start = 2;
while ( start * start < max_n )
{
for ( int i = start; i < max_n; ++i )
{
if ( !flag[i] )
{
start = i;
break;
}
}
for ( int i = start * start; i < max_n; i += start )
{
flag[i] = 1;
}
start++;
}
int t, a, b;
scanf("%d", &t);
while ( t-- )
{
scanf("%d %d", &a, &b);
for ( int i = a; i <= b; ++i )
{
if ( !flag[i] )
{
printf("%d ", i);
}
}
printf("\n");
}
return 0;
}
此题为UESTC 1246,水题,素数筛选法。