题解 | #筛选法求素数#

筛选法求素数

https://www.nowcoder.com/practice/06c3dcc303654ef4926654023eca1e5a

#include <stdio.h>
#include <stdlib.h>

int main() {
    unsigned short len = 0;
    unsigned short *parray = NULL;
    unsigned short count = 0;           // 统计0的个数

    // 多组输入
    while (EOF != scanf("%hu", &len)) {
        if (len < 2)
            return -1;

        // 动态申请内存
        parray = (unsigned short *)calloc(len - 1, sizeof(unsigned short));
        if (NULL == parray)
            return -1;
        
        // 将2~n之间的正整数放在数组内存储
        for (unsigned short i = 0; i < len - 1; i++) {
            parray[i] = i + 2;          // 下标为0的时候写的存储的是2,然后依次递增1
        }

        // 将数组中2之后的所有能被2整除的数清0,再将3之后的所有能被3整除的数清0 ,以此类推,直到n为止
        for (int i = 1; i < len - 1; i++) {         // 不包含2
            for (int j = i; j < len - 1; j++) {
                // 判断是不是素数
                if (0 == parray[j] % (i + 1))
                    parray[j] = 0;
            }
        }

        // 输出素数
        for (int i = 0; i < len - 1; i++) {
            // 数组中不为0 的数即为素数
            if (0 != parray[i])
                printf("%hu ", parray[i]);
            else        // 统计数组中2之后被清0 的个数
                count++;
        }

        // 换行+输出输出数组中2之后被清0 的个数
        printf("\n%hu\n", count);

        // 释放内存
        free(parray);
        parray = NULL;
    }

    return 0;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 11:55
点赞 评论 收藏
分享
05-20 21:57
已编辑
门头沟学院 Java
喜欢吃卤蛋的悲伤蛙在...:建信融通没消息吧,我2说有实习挂简历不理了
点赞 评论 收藏
分享
那一天的Java_J...:他本来公司就是做这个的,不就是正常的游戏客户端和服务器开发,软硬件联动,有啥恶心不恶心的,提前告诉你就是怕你接受不了,接受不了就没必要再往后走流程浪费时间,虽然这公司是一坨。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 13:47
机械打工仔:你自己匿名可以,这么好的公司就别给它匿名了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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