解题思路以及注意事项:

  1. 打表法,大家要学会用这种奇异的方法来解这一题,不然怎么凸显我们的逼格呢?

  2. 对1到1000进行遍历,让所有的非素数为1,素数为0,然后我们需要看一个数是

    不是素数的时候就简单了,只需要看看数组里那个位置存的是0还是1就可以了。

  3. 2是素数,则4不是素数,6不是,后面就是偶数了(判断所以能被2整除的数),

    i+1为3,j=6不是,6+3,不是(所以3 的倍数的全不是素数),就是这样类似的方

    法就可以让数组质数的位置里面存1。

实例代码:

#include"stdio.h" 
//打表法
#include"math.h"
void prime();
int a[1000]={0};
//定义全局的数组a[1000],也可以定义到main()里面,不过那样需要传参
int main()
//不要定义到prime里面,prime()调用完毕所有的数据将不可知
{
    int i,number,check=0;
    prime();
    scanf("%d",&number);
    if(a[number]==0)
    {
        printf("prime\n");
    }
    else
    {
    printf("not prime\n");
    }
    return 0;
}
void prime()
{
    int i=2,j;
    for(i=2;i<1000;i++)/
    for(j=i+i;j<1000;j+=i)
    {
        a[j]=1;
//让这些数(不是素数)全部为1,其余为0;
    }
}

大家还有什么不懂的就请到下面评论区留言,小方会为大家解答

点赞(17)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 8 条评论

q330226 7年前 回复TA
@q330226 提示编译错误
q330226 7年前 回复TA
26行错了,多了一个/,报错了
大魔王 7年前 回复TA
666,不过好像输入1时不对
验题君 7年前 回复TA
666
FtSan 7年前 回复TA
@FtSan 不错哦
Mister-小方 7年前 回复TA
@FtSan 已经改正
Mister-小方 7年前 回复TA
@FtSan 可以这么说
FtSan 7年前 回复TA
好像称呼上有点错误,质数就是素数,你想表达的是素数存0,非素数存1吧