re 求教
  • 板块灌水区
  • 楼主Xu_Jinyi_2011
  • 当前回复3
  • 已保存回复3
  • 发布时间2024/10/25 21:14
  • 上次更新2024/10/25 21:24:17
查看原帖
re 求教
1136033
Xu_Jinyi_2011楼主2024/10/25 21:14

rt

#include <iostream>
#include <bitset>
using namespace std;

int n, q;
bitset<(int)1e8 + 10> isprime; 
int prime[(int)1e8 + 10], top;

int main() {
	scanf("%d%d", &n, &q);
	for (int i = 2; i <= n; i ++) {
		if (!isprime[i]) {
			prime[top ++] = i;
		}
		for (int j = 0; j < top; j ++) {
			isprime[i * prime[j]] = 1;
			if (i % prime[j] == 0) break; 
		}
	}
	while (q --) {
		int x;
		scanf("%d", &x);
		printf("%d\n", prime[x - 1]);
	}
	return 0;
}
2024/10/25 21:14
加载中...