显示素数(Java实现)

什么是素数?

大于1的整数,如果它的正因子只有1和它本身,那么该整数就是素数,例如:2,3,5,7…而4,6,8,9不是

该问题可以分解成以下子问题:

  1. 判断一个数是否是素数
  2. 统计素数的个数
  3. 打印素数,每行打印10个

源代码如下:

package com.liuhuan.java;

public class PrimeNumberMethod {

	/**
	 * 把该问题分解成确定素数以及打印出素数
	 * */
	public static void main(String[] args) {
		System.out.println("The first 50 prime numbers are \n");
		printPrimeNumber(50);
	
	}
	
	/** 打印素数 */
	public static void printPrimeNumber(int numberOfPrime){
		final int NUMBER_OF_PRIME_PER_LINE = 10;
		int count = 0;
		int number = 2;
		while(count < numberOfPrime){
			if(isPrime(number)){
				count++;
				// 每10个换一行打印
				if(count % NUMBER_OF_PRIME_PER_LINE == 0){
					System.out.printf("%-5s\n", number);//格式化打印
				}else{
					System.out.printf("%-5s", number);
				}
			}
			number++;
		}
		
	}
	
	/** 判断是否为素数 */
	public static boolean isPrime(int number){
		for(int divisor = 2; divisor <= number / 2; divisor++){
			if(number % divisor == 0){
				return false;
			}
		}
		return true;
	}

}

输出结果为:The first 50 prime numbers are 

2    3    5    7    11   13   17   19   23   29   
31   37   41   43   47   53   59   61   67   71   
73   79   83   89   97   101  103  107  109  113  
127  131  137  139  149  151  157  163  167  173  
179  181  191  193  197  199  211  223  227  229  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值