H106 | 幸运数
题目
分析
题目已经给出思路:类似素数筛;
因此,可以借助素数筛模板;
需要改动的地方:
筛选条件:候选素数的位置序号 模 当前正在确认的素数 = 0,则标记为非幸运数;
定义一个辅助数组:候选素数数组lucky,用于获取素数和其位置信息;
代码
#include <iostream>
using namespace std;
int main() {
int n, m;
cin >> m >> n;
int is_lucky[n] = {0};
int lucky[n];
for (int i = 2; i < n; i++) {
if (is_lucky[i]) continue;
int temp = 0;
for (int j = 1; j < n; j++) {
if (is_lucky[j] == 0) {
lucky[++temp] = j;
}
}
for (int j = i; j <= temp; j++) {
if (j % i == 0) is_lucky[lucky[j]] = 1;
}
}
int flag = 0;
for (int i = m+1; i < n; i++)
if (is_lucky[i] == 0)
flag++;
cout << flag;
return 0;
}