Boboxiaobaier 2023-01-09 10:23 采纳率: 50%
浏览 32
已结题

翁恺c语言习题集提问

有人能解释一下这个素数表的代码吗?

#include <stdio.h>

int main(){
    const int maxnumber=25;  //数组的大小 
    int isprime[maxnumber];  //定义数组 
    int i;
    int x;
    for(i=0;i<maxnumber;i++){
        isprime[i]=1;
    }
    for(x=2;x<maxnumber;x++){
        if(isprime[x]){
            for(i=2;i*x<maxnumber;i++){
                isprime[i*x]=0;
            }
        }
    }
    for(i=2;i<maxnumber;i++){
        if(isprime[i]){
            printf("%d\t",i);
        }
    }
    printf("\n");
    return 0;
}

输出是这样的

img

这段代码的前面不是定义了一个长度为25的数组吗?为什么不是输入前25位的素数而是输出了25之前的素质?

  • 写回答

3条回答 默认 最新

  • 「已注销」 Python领域优质创作者 2023-01-09 11:13
    关注

    我来为题主解答一下。
    这里面用的是筛法,不懂可以百度。
    我只解释代码部分:
    首先定义一个数组,长度为25,下标是0-24,表示0-24这几个数字,也就是25以内的自然数。
    先把所有的数字状态标记为是素数!
    因为2是最小的素数,所以从2开始遍历即可,后面处理的时候也从2开始识别。
    遍历的过程中,对于每一个数,只要它是素数,那么它的倍数都不是素数,标记为非素数的状态。
    最后扫描一遍,还有素数标记的数字输出即可。
    开始定义的数组,本就是筛选的数值范围,而不是素数的个数!
    如果我的回答对你有帮助,还望采纳!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 1月16日
  • 已采纳回答 1月9日
  • 创建了问题 1月9日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部