java输出100nei素数,输出指定范围内的素数(质数)

这里最近看到了一个方法Sieve of Eratosthenes的方法,突然觉得以前的方法太坑了,我以前都是直接使用穷举法。

先说一下我理解的原理:

首先任何一个大于2的合数都等于一个素数乘以一个正整数,根据这个就可以开始推下面的方法。

问题:求1-n的所有素数

步骤:

1、创建一个n大小的数组A,将1标记为非素数,将2标记为素数,然后将3-n中所有的2的倍数标记为合数,同时将2赋值给K;

2、判断A中大于K的数是否已经全部被标记或者K等于n,如果是空跳到第4步;

3、求得A中最小的未标记的数m,将m标记为素数,将B中所有m的倍数标记为合数,同时将m赋值给K,返回第2步;

4、输出数组A中所有素数。

下面贴出代码:

#include

#include

#define UNLABELED 0 //未标记

#define PRINE 1 //素数

#define COMPOSITE 2 //合数

#define NOPRINE 3 //非素数

#define SIZE 100

int main()

{

int i = 0; //i表示整数和对应的下标

int j = 0; //j表示正要处理的素数j之前的已处理j之后的未处理

int k = 0; //k表示正在处理的j的倍数从2开始到 j * k < SIZE

int *p = NULL; //控制循环

int a[SIZE + 1] = { 0 }; //下标表示整数内容判断是否为素数

for (p = a; p < a + SIZE; ++p) { //初始化数组全是UNLABELED

*p = UNLABELED;

}

p = NULL;

a[0] = a[1] = NOPRINE; //设置前面两个不是素数的数的状态为NOPRINE

i = 2;

while (i < SIZE + 1) {

//判断是否未标记,找到下一个素数

if (a[i] == UNLABELED) {

j = i;

a[i++] = PRINE;

}

else {

//已经标记了继续i++向下走

i++;

continue;

}

for (k = 2; j * k < SIZE; ++k) { //处理素数的倍数

a[j * k] = COMPOSITE;

}

}

for (p = a; p < a + SIZE; ++p) { //打印出素数

if (*p == PRINE) {

printf("%8d", p - a);

}

}

p = NULL;

printf("\n");

system("pause");

return 0;

}

我把运行结果复制一遍吧,之前没仔细看了,计算到一千,但是999没有访问到,所以1000的时候999打出来了,100的时候99打出来了,多谢指点了。

一个是1-100

cdc9a315478affeb3f1cc84e20613720.png

这个是1-1000

d918c46109f73bb75342a4ca26ff0b1f.png

-_-.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值