将一个大于6的偶数拆成俩质数之和

任何一个大于六的偶数可以拆分成两个质数的和

要求:从控制台输入一个大于6的偶数,然后打印出这个数符合歌德巴赫猜想的所有可能。

package day03;

import java.util.Scanner;

public class D3hw8 {
	//将偶数拆分成俩质数的和
	public static void main(String[] args) {
		int num=inPut();
		outPut(num);
		
	}
	
	public static int inPut(){
		//输入数字并通过检验确定一个符合要求的数
		Scanner sc=new Scanner(System.in);
		System.out.println("请输入大于6的偶数:");
		int num=sc.nextInt();
		if(num%2!=0||num<=6){
			System.out.println("输入错误,请重新输入大于6的偶数:");
			return inPut();//错误则返回inPut()继续输入
		}
		return num;//正确则返回num值
	}
	
	public static boolean isPrim(int num){
		//判断是否是质数
		for(int i=2;i<=Math.sqrt((double)num);i++){
			if(num%i==0){
				return false;
			}
		}
		return true;
	}
	
	public static void outPut(int num){
		//输出所有符合条件的质数对
		for(int i=2;i<=num/2;i++){
			if(isPrim(i)==true&&isPrim(num-i)==true){	
				System.out.println(i+" "+(num-i));
			}
		}
	}


}


你可能感兴趣的:(java学习)