大厂Java笔试题之找出组成一个偶数最大的两个素数

题目:找出组成一个大于2的偶数最接近的两个素数。

比如 输入20 输出7 13

注意:这里有一个理论,任意一个大于2的偶数,都能找到2个素数,相加等于这个偶数。

java 复制代码
public class Demo10 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int a = in.nextInt();
            int[] number = getNumber(a);
            System.out.println(number[0]);
            System.out.println(number[1]);
        }
    }
    
    private static int[] getNumber(int num) { // 获取两个最接近的素数
        if (num % 2 != 0 || num <= 2) {
            throw new IllegalArgumentException("参数错误");
        }
        int initdiff = num;
        for (int i = 2; i < num; i++) {
            if (isSushu(i) && isSushu(num - i) && num >= (2 * i)) {
                int diff = num - 2 * i;
                if (diff < initdiff) {
                    initdiff = diff;
                }
            }
        }
        int num1 = (num - initdiff) / 2;
        int num2 = num - num1;
        int[] res = new int[2];
        res[0] = num1;
        res[1] = num2;
        return res;
    }

    private static boolean isSushu(int num) { // 判断是否素数
        if (num <= 1) {
            return false;
        }
        for (int i = 2; i <= Math.sqrt(num); i++) {
            if (num % i == 0) {
                return false;
            }
        }
        return true;
    }
}

如果大家需要视频版本的讲解,欢迎关注我的B站:

相关推荐
ayt0078 分钟前
Netty 4.2核心类解析:SingleThreadIoEventLoop的设计哲学与实现
java·网络
无名-CODING10 分钟前
Java 爬虫进阶:动态网页、多线程与 WebMagic 框架实战
java·爬虫·okhttp
weixin_7042660512 分钟前
Spring 注解驱动开发与 Spring Boot 核心知识点梳理
java·spring boot·spring
开开心心就好12 分钟前
伪装文件历史记录!修改时间的黑科技软件
java·前端·科技·r语言·edge·pdf·语音识别
8Qi815 分钟前
Redis哨兵模式(Sentinel)深度解析
java·数据库·redis·分布式·缓存·sentinel
wangchunting22 分钟前
数据结构-树
java·数据结构
无籽西瓜a25 分钟前
【西瓜带你学设计模式 | 第五期 - 建造者模式】建造者模式 —— 产品构建实现、优缺点与适用场景及模式区别
java·后端·设计模式·软件工程·建造者模式
wzl2026121328 分钟前
《基于企微会话存档的精准发送策略:从互动数据分析到防折叠群发》
java·数据分析·企业微信
DC...29 分钟前
【力控】混合位置 / 力控制
算法·机器人·力控
Rabitebla30 分钟前
归并排序(MergeSort)完全指南 —— 从原理到非递归实现
c语言·数据结构·c++·算法·排序算法