C和指针之用拉托斯特尼筛方法(Eratosthenes)查找区间质素个数
【摘要】 1、问题
用拉托斯特尼筛方法(Eratosthenes)查找区间质素个数
2、代码实现
#include <stdio.h>#define LEN 10000/** *Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数, * 再用下一个素数,也就是3筛,把3留下,把3的倍数...
1、问题
用拉托斯特尼筛方法(Eratosthenes)查找区间质素个数
2、代码实现
-
#include <stdio.h>
-
#define LEN 10000
-
/**
-
*Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数,
-
* 再用下一个素数,也就是3筛,把3留下,把3的倍数不是质数,接下去用下一个素数5筛,把5留下,把5的倍数不是质数,
-
*c不断重下去......
-
* 求区间质素个数
-
*/
-
-
int get_all(char *a, int start, int end)
-
{
-
if (end > LEN)
-
return 0;
-
int count = 0;
-
//初始化,把每个元素设置'1'
-
for (int i = start; i < end; i++)
-
*(a + i) = '1';
-
//把下标不是质素的数组元素设置为‘0’
-
for (int i = 2; i * i <= end; ++i)
-
if (*(a + i) == '1')
-
for (int j = 2; j * i < end; ++j)
-
*(a + i * j) = '0';
-
//打印质数
-
for (int i = start; i < end; ++i)
-
if (*(a + i) == '1')
-
文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。
原文链接:chenyu.blog.csdn.net/article/details/78389431
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)