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、代码实现


       #include <stdio.h>
       #define LEN 20
       /**
        *Eratosthenes-埃拉托斯特尼筛方法找质数,给出要筛数值的范围n,先用2去筛,2的倍数不是质数,
        * 再用下一个素数,也就是3筛,把3留下,把3的倍数不是质数,接下去用下一个素数5筛,把5留下,把5的倍数不是质数,
        *c不断重复下去......
        *
        */
       int main()
       {
          char a[LEN];
          //初始化,把每个元素设置'1'
          for (int i = 0; i < LEN; i++)
        *(a + i) = '1';
        //把下标不是质素的数组元素设置为‘0’
        for (int i = 2; i * i <= LEN; ++i)
        if (*(a + i) == '1')
        for (int j = 2; j * i < LEN; ++j)
        *(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个月内不可修改。