868. 筛质数

Posted 幽殇默

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了868. 筛质数相关的知识,希望对你有一定的参考价值。

在这里插入图片描述
https://www.acwing.com/problem/content/870/

#include<cstdio>
#include<iostream>
using namespace std;
const int N=1e5+10;
int prime[N],cnt;
bool st[1000005];
int n;
void f(int x)
{
	for(int i=2;i<=x;i++)
	{
		if(!st[i]) prime[cnt++]=i;
		for(int j=0;prime[j]<=x/i;j++)
		{
			st[prime[j]*i] =true;
			if(i%prime[j]==0) break;
		}
	} 
} 
int main(void)
{
	cin>>n;
	f(n);
	cout<<cnt; 
	return 0;
} 

以上是关于868. 筛质数的主要内容,如果未能解决你的问题,请参考以下文章

C++线性筛——筛质数详解

poj2739(尺取法+质数筛)

判断质数与筛质数

质数判断(欧拉筛法)

Eular质数筛法

数论线性筛质数