文章目录
素数
- 素数
- 埃氏筛
- 算法思想
- 时间复杂度
- Java编程实现
- 算法优化
素数也称质数,是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。 最基本的质数:2, 3, 5, 7, 11, 13, 17, 19, ……
埃氏筛埃拉托斯特尼筛法,简称埃氏筛,是一种由希腊数学家埃拉托斯特尼所提出的一种简单检定素数的算法。
要得到自然数n以内的全部素数,必须把不大于根号n的所有素数的倍数剔除,剩下的就是素数。
算法思想给出要筛数值的范围n,找出以内的素数。
先用2去筛,即把2留下,把2的倍数剔除掉; 再用下一个质数,也就是3筛,把3留下,把3的倍数剔除掉; 接下去用下一个质数5筛,把5留下,把5的倍数剔除掉; 不断重复下去… 最终,把所有不大于根号n的所有素数的倍数剔除,剩下的就是素数。
- 如果n是质数,那么2n, 3n, 4n, …这些n的倍数肯定都不是质数。
- 如果选的数要多,那么要选的每个数要尽可能小。
关注
打赏
热门博文
- 【Linux】Ubuntu20.04安装和卸载MySQL8
- 【Linux】Ubuntu 20.04 报错 curl: (23) Failure writing output to destination 的解决方法
- 【Java】JUnit 4.13.2 警告 ‘assertEquals(double, double)‘ is deprecated 的解决方法
- 【JavaScript】处理 @parcel/transformer-js: Browser scripts cannot have imports or exports.
- 【Python】处理TypeError: Plain typing.NoReturn is not valid as type argument
- 【Python】Matplotlib可视化50例
- 【C语言】C语言修改MySQL数据库
- 【Java】从默认包导入类和对象报错的解决方法
- 【Java】panel.getGraphics()报错空指针异常的解决方法
- 【Java】IDEA编译Java项目报错 java: 找不到符号 的解决方法