C和指针之Eratosthenes-埃拉托斯特尼筛方法找质数

举报
chenyu 发表于 2021/07/27 01:55:59 2021/07/27
【摘要】 1、问题  *Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数,     * 再用下一个素数,也就是3筛,把3留下,把3的倍数不是质数,接下去用下一个素数5筛,把5留下,把5的倍数不是质数,  *c不断重复下去......    ...

1、问题

 *Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数,   

 * 再用下一个素数,也就是3筛,把3留下,把3的倍数不是质数,接下去用下一个素数5筛,把5留下,把5的倍数不是质数,

 *c不断重复下去......

 

 

2、代码实现


   
  1. #include <stdio.h>
  2. #define LEN 20
  3. /**
  4. *Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数,
  5. * 再用下一个素数,也就是3筛,把3留下,把3的倍数不是质数,接下去用下一个素数5筛,把5留下,把5的倍数不是质数,
  6. *c不断重复下去......
  7. *
  8. */
  9. int main()
  10. {
  11. char a[LEN];
  12. //初始化,把每个元素设置'1'
  13. for (int i = 0; i < LEN; i++)
  14. *(a + i) = '1';
  15. //把下标不是质素的数组元素设置为‘0
  16. for (int i = 2; i * i <= LEN; ++i)
  17. if (*(a + i) == '1')
  18. for (int j = 2; j * i < LEN; ++j)
  19. *(a + i * j) 

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/78389296

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。