*【每日一题 提高题】[蓝桥杯 2022 国 A] 选素数

选素数

小蓝有一个数 x,每次操作小蓝会选择一个小于 x 的素数 p,然后在 x 成为 p 的倍数前不断将 x 加 1,(如果 x 一开始就是 p 的倍数则 x 不变)。

小乔看到了小蓝进行了 2 次上述操作后得到的结果 n,他想知道 x 在一开始是多少。如果有多种可能,他想知道 x 一开始最小可以是多少,而如果不存在任何解,说明小乔看错了,此时请输出 −1。
输入格式

输入一行包含一个整数 n,表示经过两次操作后 x 的值。
输出格式

输出一行包含一个整数表示 x 的初始值。如果有多个解,输出最小的。如果不存在解,请输出 −1

这个题主要考察质因数分解和质数判断

首先质数的判断,这个太常见了,这里就不多赘述

java 复制代码
private static boolean isPrime(int n){
        if (n<2)return false;
        if (n==2||n==3)return true;
        if (n%6!=1&&n%6!=5)return false;
        for (int i = 5; i*i<= n ; i+=6) {
            if (n%i==0||n%(i+2)==0){
                return false;
            }
        }
        return true;
    }

然后是质因数分解,这里用了 List 集合去装分解出来的质数

java 复制代码
private static List<Integer> prime(int n){
        List<Integer> ans  = new LinkedList<>();
        for(int i = 2; i <= n/i ; i++){//判断条件用n/i,以防i*i<=n发生溢出
            int a = 0;//每次循环都要清零
            while(n % i == 0){
                n /= i;
                a++;
            }
            if(a > 0)
                ans.add(i);
        }
        //若该数是质数,那么应该将自身(n)也加入
        if(n > 1) ans.add(n);
        return ans;
    }

最后就是根据题意进行模拟,a0→a1→ a2

(依次进行第一次操作、第二次操作)。

java 复制代码
import java.util.*;//导入万能类 当然也不是很万能
public class Main {
    static List<Integer> oList = new LinkedList<>();//需要用到的集合
    public static void main(String[] args) {
    //标准输入 一个n
       Scanner sc  = new Scanner(System.in);
       int n = sc.nextInt();
       
        if (isPrime(n)){
        //如果输入数为质数,那么打印-1。因为我们的n应该是质数的倍数,且必须至少为2倍(题目中说了选择一个小于x的素数p,所以至少是2倍)。
            System.out.println("-1");
        }else {
            oList = prime(n);
            //对其质因数分解,并用集合装好
            int minstart = Integer.MAX_VALUE;//定义所求的最小开始的a0,赋值为Integer最大值,为了后面获取最小值
            for (int i = 0; i < oList.size(); i++) {
            //遍历质因数集合
                int last_left = n-oList.get(i);
                //下面对第一次操作后可能的数组遍历
                for (int j = last_left+1; j <= n ; j++) {
                //这里的范围为什么是从last_left+1到n
                //假设第二次操作选择的是oList.get(i)作为质数,那么第二次操作前的数(a1)不会小于n-oList.get(i)
                //上次操作前的数字(a1)必然在左边界加1和n之间。(为什么是n?因为n可能本身就是某个质数的倍数,然后这次操作又选了该质数,则n不变)
                    if (isPrime(j)){
                        continue;
                        //跟上面一样,不可能是质数。
                    }
                    List<Integer> temp = prime(j);//继续对上个数进行质因数分解
                    int max = Collections.max(temp);
                    //找出最大的质因数作为第一次操作选择的质数,这样能使起始数字(即a0)尽可能小
                    minstart = Math.min(j-max+1,minstart);//更新维护最小数字
                   
                }
            }
            if (minstart==Integer.MAX_VALUE){
                System.out.println("-1");
            }else {
                System.out.println(minstart);
            }
        }

    }
    //质数的判断
    private static boolean isPrime(int n){
        if (n<2)return false;
        if (n==2||n==3)return true;
        if (n%6!=1&&n%6!=5)return false;
        for (int i = 5; i*i<= n ; i+=6) {
            if (n%i==0||n%(i+2)==0){
                return false;
            }
        }
        return true;
    }
    //对n进行质因数分解
    private static List<Integer> prime(int n){
        List<Integer> ans  = new LinkedList<>();
        for(int i = 2; i <= n/i ; i++){//判断条件用n/i,以防i*i<=n发生溢出
            int a = 0;//每次循环都要清零
            while(n % i == 0){
                n /= i;
                a++;
            }
            if(a > 0)
                ans.add(i);
        }
        //若该数是质数,那么应该将自身(n)也加入
        if(n > 1) ans.add(n);
        return ans;
    }
}
相关推荐
寻星探路7 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
你撅嘴真丑10 小时前
第九章-数字三角形
算法
曹牧10 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
uesowys10 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder10 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮10 小时前
AI 视觉连载1:像素
算法
爬山算法11 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
智驱力人工智能11 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
kfyty72511 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai