题解 | #查找组成一个偶数最接近的两个素数#
查找组成一个偶数最接近的两个素数
https://www.nowcoder.com/practice/f8538f9ae3f1484fb137789dec6eedb9
看了一下,这题解法很多,我也写一下我的解法,思路是直接找到最小的差值,然后根据和差公式直接输出值
import java.io.IOException;
import java.util.Scanner;
public class Main {
public static void main(String[] args) throws IOException {
Scanner sc = new Scanner(System.in);
int num = sc.nextInt();
// 记录最小的差值
int minDiffer = Integer.MAX_VALUE;
for (int i = 1; i < num; ++i) {
if (isPrime(i) && isPrime(num - i)) {
int differ = Math.abs(num - i - i);
minDiffer = Math.min(differ, minDiffer);
}
}
// 和差公式
System.out.println((num - minDiffer) / 2);
System.out.println((num + minDiffer) / 2);
}
public static boolean isPrime(int num) {
for (int i = 2; i <= Math.sqrt(num); ++i) {
if (num % i == 0) {
return false;
}
}
return true;
}
}

