素数筛

##素数##
素数即质数,只能被自身和一整除。
一般暴力找素数,O(n2)或者O(nsqrt(n))
这样耗费时间太多,所以我们用筛法来处理
##素数筛##
素数筛通过将非素数筛掉来找素数,是重要的数论工具
###一般筛法### --埃氏筛
一般筛法接近O(n)的复杂度,但比快速筛慢

bool mark[Max];//标记是否为素数
int ss[Max];//将素数存入数组
void prime()//筛法
{
	memset(mark,0,sizeof(mark);
	int tot=0;
	for(int i=2;i<Max;i++)
	{
		if(!mark[i])
		{
			ss[tot++]=i;
			for(int j=2*i;j<Max;j+=i)//筛掉素数的倍数
			mark[j]=1;
		}
	}
}

###快速筛法###
快速筛法的复杂度一般为O(n) --线性筛

bool mark[Max];//标记是否为素数
int ss[Max];//将素数存入数组
void prime()//筛法
{
	memset(mark,0,sizeof(mark);
	int tot=0;
	for(int i=2;i<Max;i++)
	{
		if(!mark[i])ss[tot++]=i;
		for(int j=0;j<tot&&i*ss[j]<Max;j++)
		{
			mark[i*ss[j]=1;
			if(i%ss[j]==0)break;//保证筛过的非素数只筛一次
		}
	}
}
全部评论

相关推荐

12-18 18:50
已编辑
门头沟学院 golang
牛客33637108...:重点是要事已密成,在没有进入这家公司之前,不要有任何的泄露信息,我之前跟你一样,面了一家光伏设备厂,底薪7500加上出差补贴大概有13,000左右,已经给了口头offer了,甚至要了我的在校成绩的所有信息,还向我要了三方的网签二维码,到后面还是毁约了,我干过最愚蠢的事情就是向同学透露要签三方的事,之后的失败只会让他们幸灾乐祸,这是即将结束的大学生活给我的最后一课,不要相信任何的口头三方,该面的就去面,甚至签了三方也有毁约的可能,就像我现在签了三方还在外面实习呢,春招还是要继续参加的,不能停止面试,不然到后面毁三方的时候,重新捡起的面试很麻烦的,这是我一点点小小的见解。
点赞 评论 收藏
分享
回家当保安:复旦✌🏻,佬你的简历感觉挺好的,寒假日常hc比较少。佬可以过完年之后再试试,日常实习hc比较充足
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务