前言
今天是中秋节,祝大家中秋吃饱月饼
少有的一遍过,不难
上题
#include <iostream>
using namespace std;
int main() {
int M,N,i,j,k = 0,count = 0; //i:自然递增的数 k:素数个数 count:一行内输出素数个数
cin >> M >> N;
for(i = 2;k <= N; i++) {
for(j = 2;j * j <= i; j++)
if(i % j == 0) break;
if(j * j > i) { //若为素数
k++;
if(k >= M && k <= N) {
if(count++) cout << " "; //先判断再++,若一行内输出素数个数为0则不输出空格
cout << i; //输出素数
if(count == 10) {
count = 0;
cout << endl;
}
}
}
}
return 0;
}
大佬代码
#include <iostream>
#include <vector>
using namespace std;
bool isprime(int a) {
for (int i = 2; i * i <= a; i++)
if(a % i == 0) return false;
return true;
}
int main() {
int M, N, num = 2, cnt = 0;
cin >> M >> N;
vector<int> v;
while (cnt < N) {
if (isprime(num)) {
cnt++;
if (cnt >= M) v.push_back(num);
}
num++;
}
cnt = 0;
for (int i = 0; i < v.size(); i++) {
cnt++;
if (cnt % 10 != 1) printf(" ");
printf("%d", v[i]);
if (cnt % 10 == 0) printf("\n");
}
return 0;
}
又是vector,我好像还没填坑...
一点话说
中秋乐!