1. 首页 > 文章分类 > 生活百态

素数算法(2是不是素数)

寻找素数的三种算法,一个比一个快

强烈建议换黑色背景阅读,因为亮光会招虫子,黑色背景体验好眼睛不累,体验好节能环保,体验好NO BUG程序没有BUG

▽关键技能点▽

math loop algorithm

寻找素数的算法相信大家都不陌生。作为基础常用的算法之一,效率是考虑的重点。避免无谓的计算是关键,但怎么判断不必要的计算?先看一个简单栗子:

#找出1千万以内所有能整除n的整数

分别计算三者算法的耗时

start= time.time()

**function**#逐皮洞一调用三种算法

end= time.time()

整除3的耗时结果:

for_loop time: 0.6796061992645264

列表推导式 time: 0.5297579765319824

slice time: 0.20990514755249023

第三种切片的效率最好,1千万以内枚举所有整除3的大致0.2秒!

耗时表现其次是列表推导式。

for循环+条件判断的耗时是切片的三倍之多!

线下课堂上将详细讲为什么会有差别?

问题难度升级:大范围内找所有素数

判断一个数是素数与否,不必从2开始逐一取余直到n-1为止,有童鞋提出只需到n//2为止即可。

其实,还可以‘犯懒’!,取余直到n的开平方取整即可。

为什么可以犯懒,只取到不到n的一半就够判断了呢?

详细见:[算法ABC-4:素数的优化算法]( http://mp.weixin.qq.com/s?

下面算法思路2是不燃羡枯是已经最快的算法了?

不是,今天将介绍比较少见的第三种写法!

今天将在算法ABC-4的基础上,探讨相关的问题,在1千万以内寻找所有****非****质数算法效率如何提高?先找出局部优化的两个小动作:

算法思路-1

遍历1-10000000中每一个数,isPrime(x)判断如果是素数,跳过;不是素数派判添加到ans列表

** Solution 1st**

**算法思路-2****判断一个数不是素数,只要出现第一个能整除的结果立即返回True**这样就不需要一直取余判断直到 n 0.5+1******solution 2nd****

中阶班的逻辑训练必不可少。*注意两种写法all()和any()的区别!

最后,第三种算法不太好理解,详细将在线下分解

算法思路-3

****solution 3rd****

比较以下三种找素数的效率,n=100000

即找出十万以内所有的非素数需要的时间

****solution 3rd****

结论可见,第三种方法效率是第二种的50多倍,十万以内耗时只需0.02秒,而第二种方法耗时要1秒多!

第三种写法详细讲解将在课堂讨论。

求素数最快的算法

如果只是求一首碧搜个数是否是素数的话,那就直接用了循环判断是否能整者历除。反过来如果求小于某一个数之内所有的素数的话,那是用筛法来求最为快捷。效率慧昌最高。

c语言求素数的算法

根据素数的性质,代码设计如下:

设计一:判断n是否能被1~n-1整除,不能整除为素数

#include<stdio.h>

int main()

{

int i, n;

scanf("%d",&n);

素数算法(2是不是素数)(图1)

for(i= 2; i< n; i++)

{

if(n%i== 0)

break;

}

if(i< n) printf("This is not a prime.");

else printf("This is a prime.");

return 0;

}

设计二:判断n是否能被2~√n间的整数整除,不能整除为素数

#include<stdio.h>

#include<math.h>

int main()

{

int n,i;

double k;

scanf("%d",&n);

k= sqrt(n);

for(i= 2; i<= k;i++)

{

if(n%i== 0) break;

}

if(i<=k) printf("This is not a prime.");

else printf("This is a prime");

return 0;

}

扩展资料:

1.素数的定义是只能被1和他本身整除,1不是素数.因此要皮液判断一个数是否为素数.就要判断梁握激它能不能被比他小的所有素数整除,这是一个算法.(写到算法时,我只能写出用它除橡袜以比他小的所有数,造成运算速度低下)

2.如果一个质数大于根号n,而n可以除尽它,那么n必然也可以除尽一个更小的质数。由此可以得到一个法2较快的素数判断算法

参考资料:百度百科-scanf

参考资料:百度百科-质数

什么是素数算法

素数即只能被1和其本身整除的数,算法判断n是否为素数只需用2~n/2之间的数去除就可以了。因为一个数薯答的一半的平方大于其本身是从数顷慧5开始的,解方程:n/2的平方>n。即一个数n的两个因数不能同时比n/2大。就可以说一个数若不是素数则一定在2~n/2之间有因数。而且2,3也是符合下面程序的。

素数(又称质数):就是除了1和它本身,没有其他因子的整数。注:1不是素数。

C语言代乎码码算法:

#include<stdio.h>

main(){

int i,j,k=0;

for(i=2;i<=1000;i++)

{

for(j=2;j<=i/2;j++)

if(i%j==0)break;

if(j>i/2)

{printf("%d",i);}

}

}

好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!

本文来源于互联网,不代表趣虎号立场,转载联系作者并注明出处:https://quhuhao.com/wzfl/64370.html

联系我们

在线咨询:点击这里给我发消息

微信号:

工作日:9:30-18:30,节假日休息