查找组成一个偶数最接近的两个素数

牛客网华为机试题

描述

任意一个偶数(大于2)都可以由2个素数组成,组成偶数的2个素数有很多种情况,本题目要求输出组成指定偶数的两个素数差值最小的素数对。

数据范围:

输入的数据满足 4 \le n \le 1000

输入描述:

输入一个大于2的偶数

输出描述:

从小到大输出两个素数

示例1

输入:

20

输出:

7
13

示例2

输入:

4

输出:

2
2

代码

import java.util.Scanner;

/**
 * @author hll[yellowdradra@foxmail.com]
 * @since 2023-03-16 10:42
 **/
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        minDiff(in.nextInt());
    }

    public static void minDiff(int n) {
        for (int i = n >> 1; i > 0; i--) {
            if (isPrimeQuickly(i) && isPrimeQuickly(n - i)) {
                System.out.printf("%s\n%s\n", i, n - i);
                break;
            }
        }
    }

    public static boolean isPrimeQuickly(int n) {
        if (n == 2 || n == 3) {
            return true;
        }
        // 等价于 n % 2 == 0 即n是偶数
        if ((n & 1) == 0 || n <= 1) {
            return false;
        }
        int r = n % 6;
        if (r != 5 && r != 1) {
            return false;
        }
        int sqrt = (int) Math.sqrt(n);
        // 保证i为奇数
        for (int i = 5; i <= sqrt; i += 6) {
            if (n % i == 0 || n % (i + 2) == 0) {
                return false;
            }
        }
        return true;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容