java 筛法_埃氏筛法求素数 java 代码

Posted by 撒得一地 on 2016年4月20日 in 杂谈

4cb15082d778157592c90ea2b0676428.png

埃氏筛法求素数,下面是完整的java代码:

import java.util.Scanner;

/**

* Author:  HF

* Blog:    blog.nicerData.com | Email: androidiosgood@gmail.com

* Date:    2014/5/4

* Description:  埃氏筛法求素数

*/

public class FilterPrime {

public static void main(String[] args) {

System.out.println("Enter an integer number:");

Scanner input = new Scanner(System.in);

int number = input.nextInt();

Prime(number);

}//main

//利用埃氏筛法进行筛选的过程

public static void Prime(int number) {

//假设一个数组,每个数组元素代表的是一个标记(Y/N)

char[] arr = new char[number + 1];

//标记Y表明是素数,N表明不是素数,初始化假设全为素数,都先标记为Y

for (int i = 0; i < arr.length; i++) {

arr[i] = 'Y';

}

for (int i = 2; i <= number; i++) {

if (arr[i] == 'Y') {

//i的初始值为2,j代表倍数,根据埃氏筛法:凡是i的j倍的数都为'N',表示筛除出来的非素数

for (int j = i; j * i <= number; j++) {

arr[i * j] = 'N';

}

}//if

}//for

//打印结果

for (int i = 2; i <= number; i++) {

if (arr[i] == 'Y') {

System.out.print(i + " ");

}

}//for

}//Prime

}

... other posts by psz1992

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值