求出n以内的所有素数

素数筛选法

蓝桥杯经典模板里面提到了这个方法
https://blog.csdn.net/weixin_41793113/article/details/88762953
如下图
求出n以内的所有素数_第1张图片

然后
https://blog.csdn.net/liukehua123/article/details/5482854
这篇文章比较详细的讲了筛选法方法,博主有个别错误可以原谅
对于这上面提到的一个问题,就是创建比变量大的数,要用到动态内存我看了下面这篇
http://c.biancheng.net/view/223.html
这篇写的非常详细
具体方法就是

int* const a = (int*)malloc(sizeof(int)*(n+1));
//a就可以看成数组名了,但是这种方法好像没办法把数组所有值赋0 

等下我好像找到方法了

#include
#include
#include
#include 

int main()
{
	int n;
	scanf("%d",&n); 
	int* const a = (int*)malloc(sizeof(int)*(n+1)); 
	memset(a, 0, sizeof(int)*(n+1));
}

然后我写的素数筛选法如下(刚刚开始打竞赛代码比较烂)

//素数筛选法 
#include
#include    //sqrt函数开方 
#include  //malloc内存分配 
#include   //memset内存初始 
int n;
void judge(int n)
{
	int* const a = (int*)malloc(sizeof(int)*(n+1)); 
	memset(a, 0, sizeof(int)*(n+1));
	*(a+1)=1;//1不是素数 
	for(int i=2;i<sqrt(n);i++)
		if(*(a+i)==0) 
			for(int j=2*i;j<n+1;j=j+i)
				*(a+j)=1;
				
	for(int i=2;i<n+1;i++)	
		if(*(a+i)==0)
			printf("%d  ",i);					
}
int main()
{
	scanf("%d",&n); 
	judge(n);
	return 0;
}

然后(这是再没找到方法之前)
https://blog.csdn.net/Frost_Bite/article/details/88878063
讲了数理知识简化时间复杂度,有很多方法
然而我只看了最简单的如下图
求出n以内的所有素数_第2张图片

你可能感兴趣的:(竞赛题,c++)