令 Pi 表示第 i 个素数。现任给两个正整数 M≤N≤104,请输出 PM 到 PN 的所有素数。
输入格式:
输入在一行中给出 M 和 N,其间以空格分隔。
输出格式:
输出从 PM 到 PN 的所有素数,每 10 个数字占 1 行,其间以空格分隔,但行末不得有多余空格。
输入样例:
5 27
输出样例:
11 13 17 19 23 29 31 37 41 43
47 53 59 61 67 71 73 79 83 89
97 101 103
解题思路:
主要是素数的函数建立;
其次要每10次输出\n,其余输出 “空格”
c++代码如下:
#include <bits/stdc++.h>
#define int long long
using namespace std;
bool is_num(int a)
{
if(a <= 1)
{
return false;
}
for(int i = 2;i<=sqrt(a);++i)
{
if(a%i == 0)
{
return false;
}
}
return true;
}
signed main()
{
int r,l;
cin >> r >> l;
if(r==0)
{
cout << endl;
}
else
{
int flage = 1;
int num = 1;
for(int i = 2;num <= l;++i)
{
if(is_num(i))
{
if(num>=r && num<=l)
{
cout << i;
if(flage % 10 == 0)
{
cout << endl;
}
else
{
if(num != l)
{
cout << " ";
}
}
++flage;
}
++num;
}
}
}
}