筛法求素数

一般:

#include<stdio.h>
int main()
{
    int a[100], i, j;
    for(i = 2; i < 100; i++)
        a[i] = 1;//令2-99都为1
    for(i = 2; i < 100/2; i++)//2 - 到 范围的一半的所有倍数
    {
        if(a[i] == 1)//还未被筛 素数不会被筛 合数会被筛
        {
            for(j = 2*i; j < 100; j=j+i)//刚开始两倍后三倍四倍
            {
                a[j] = 0;//把下标为合数的数组都为0
            }            
        }
    }
        for(i = 2; i < 100; i++)
        {
            if(a[i]!=0)//数组不为0 说明不是合数 则把这些素数打出来
            printf("%d ",i);
        }
    return 0;
}

全部评论

相关推荐

xiaowl:1. 技能堆叠没有意义,精简下,而且里面的精通、熟练等内容,其实经不起推敲,这里可以简单写清楚你在前端、后端等领域,有哪些你自己比较经验丰富熟练的技能,以及哪些有过一定涉猎,做一定区分度 2. 项目方案有些单薄,但是这个项目本身还是有很多挑战点的,你应该思考下对于里面有难题的挑战点,你是怎么解决的,避免泛泛而谈。比如,多人编辑是一个老大难问题,包括了互斥、协作等,这里可以详细讲一讲你怎么设计解决问题的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务