素数线性筛选
来源:互联网 发布:淘宝充值平台官网登录 编辑:程序博客网 时间:2024/06/06 02:50
因为线性筛选的原理是利用每个合数的最小质因子去筛选
if(i % prime[k] == 0) break;
这是让复杂度达到O(N)的关键一句。原理如下:
因为 i%prime[k] == 0 所以 prime[k] 是 i 的最小质因子
所以 i 可以分解成某个数乘以 prime[k] 即 i = n * prime[k]
我们下一个要筛选的素数是i * prime[k+1] ,然后我们分解 i 得到
n * prime[k] * prime[k+1] , 很明显这个素数可以由较大的数乘以prime[k]筛选掉
还有除了 2, 3 以外只有 6N+1,或者 6N+5 才会是素数。
6N,6N+2, 6N+3, 6N+4分别至少能被2, 2, 3, 2整除,所以不可能是素数。
int dis[2] = {4, 2};bool isprime[100000005];int prime[6000000], top;void Prime(){ int i, k, pos = 0; top = 0; prime[top++] = 2; prime[top++] = 3; for(i = 5; i <= 100000000; i += dis[pos ^= 1]){ if(!isprime[i]) prime[top++] = i; for(k = 0; i*prime[k] <= 100000000 && k < top; k++){ isprime[i*prime[k]] = true; if(i % prime[k] == 0) break; } }}
0 0
- 线性筛选素数模板
- 素数线性筛选
- 素数的线性筛选
- 线性筛选素数法
- 线性筛选素数
- 素数线性筛选法
- 素数线性筛选
- 线性筛选求素数
- 线性筛选求素数
- 【线筛】线性筛选素数
- 线性筛选素数--python
- 线性筛选素数。。。。线性哦
- 线性筛选素数(欧拉筛选)
- 浅谈—线性筛选素数
- 快速线性素数筛选[模板]
- 线性筛选素数(模板)
- 素数筛选之“普通筛选”和“线性筛选”
- 线性筛选素数和线性筛选欧拉函数【bzoj2190]
- leveldb使用时遇到的性能问题
- map的用法
- Online Judge System For SzNOI 题库 语法百题 C++ d001
- 北京数字认证股份有限公司-数字证书认证管理解决方案
- RSA算法理解
- 素数线性筛选
- 解决apache无法启动:undefined symbol: apr_ldap_ssl_init
- 归并排序
- RabbitMQ第一篇——初识RabbitMQ,简单的消息发送和接收
- Unity3d平台脚本预定义编译条件 Platform Dependent Compilation
- hibernate现有项目说明
- Java-发送邮件(附件、图片)---(三)类-Properties、Session、MimeMessage
- HUST-1010
- java中十进制转二进制转换函数