寻找素数
来源:互联网 发布:js 删除预览图片 编辑:程序博客网 时间:2024/05/16 01:37
优化的朴素方法计算n是否为素数:
即从2到n的平方根,对每一个整数判断一次n是否可以被它整除,若有这样的数字,则n为合数,若无这样的数,则n为素数。代码如下:
int is_prime(int);int is_prime(int number) { int i = 2; for (; i * i <= number; i++) { if (number % i == 0) return 0; } return 1;}
埃拉托色尼筛法(The Sieve of Eratoshenes):
步骤如下:
a>创建一个元素全部都被初始化为1的数组(代表真)。下标为素数的元素值最后会保持为1,而剩下的数组元素最后将被置为0。
b>从数组下标2开始(1不是素数也不是合数),每次处理首先找到一个值为1的数组元素,然后在剩余数组元素中,循环检测数组下标是否是那个值为1的元素的数组下标的倍数,若是,则将其元素值置为0。上述处理结束之后,值仍然为1的数组元素的下标就是素数。
实现如下:
void sieve();void sieve() { int numbers[SIZE]; int i = 0, k = 2; for (i = 0; i < SIZE; i++) numbers[i] = 1; for (k = 2; k < SIZE; k++) { if (numbers[k] == 0) continue; for (i = k + 1; i < SIZE; i++) { if (numbers[i] == 0) continue; if (i % k == 0) numbers[i] = 0; } } for (i = 2; i < SIZE; i++) if (numbers[i] == 1) printf("%d\n", i);}
结论
可以看出,对于优化的朴素方法,判断数n是否为素数的复杂度上限为
对于第一次筛选,遍历了
0 0
- 寻找素数
- 寻找素数
- 寻找素数
- 寻找素数
- 素数寻找
- 寻找素数
- 寻找素数
- 寻找素数 Google题
- C#寻找素数
- 寻找顽强素数 算法
- hdu1262寻找素数对
- 寻找素数对
- hdu1262-寻找素数对
- hdu1262 寻找素数对
- 寻找素数对
- 寻找素数对
- hdoj1262 寻找素数对
- 寻找素数对
- 【CG物理模拟系列】开篇:介绍(下)
- linux 计划任务crontab,定时打开一个图形界面
- cf448C
- IE主页被恶意软件劫持,360卫士无法修改
- SpringMVC HelloWorld实例开发及部署
- 寻找素数
- 回文数字
- [BZOJ3519][Zjoi2014][模拟]消棋子
- 使用Spring的JAVA Mail支持简化邮件发送
- 集合框架图以及一些理解与总结
- except as e中的‘e’的作用总结
- SQL Server-索引故事的遥远由来,原来是这样的?(二十八)
- Python 在Mysql中插入数据
- 浅谈Spring的PropertyPlaceholderConfigurer