[每日一道小算法(七十五)] [素数] 最近邻的素数

前言:
今天参加了一个公司的笔试,关于素数的,所以在这里贴一下。

题目描述

输入大小n的正整数数组arr[],arr[]的每个元素a取值范围为:1<=a<=100000,找到与每个元素相邻最近的一个素数并作为新的数组返回。请设计时间复杂度较优的算法,并给出时间与空间复杂度分析。
输入:
5
1
2
3
8
10
输出:
2
2
3
7
11

解题思路

这道题,我也没想到最优解题思路。完全使用暴力破解法完成的。对输入的整数两边分别查找素数。也就使用两个指针分别向两边查找。第一个找到的就是离着最近的一个素数。反正这种是最暴力的方法。我也没想到最好的,在这里贴一下,有大神想出最好的可以在这里贴一下。相互学习。

代码样例

package AiStudy;


import java.util.ArrayList;
import java.util.Scanner;

/**
 * @note 最近邻素数
 * 输入大小n的正整数数组arr[],arr[]的每个元素a取值范围为:1<=a<=100000,
 * 找到与每个元素相邻最近的一个素数并作为新的数组返回。请设计时间复杂度较优的算法,并给出时间与空间复杂度分析。
 * <p>
 * 第一行输入n,表示需要输入n个正整数,
 * 然后输入n个正整数a,1<=a<=100000
 * <p>
 * 对于每组测试数据,输出n行最近邻的素数,行末无多余空格
 */
public class Main {

    private static int makeNearestPrime(int a) {
        if(a<=2)
        {
            return 2;
        }
        if(a==3)
        {
            return 3;
        }
        int left = 0;
        int right = 0;
        int j;
        int i;
        for ( i = 1; i <a-2 ; i++) {
            for ( j= 2; j <= Math.sqrt(a+i); j++) {
                if((a+i)%j==0)
                {
                    break;
                }
            }
            if(j>Math.sqrt(a+i))
            {
                left=1;
            }
            for (j=2; j <=Math.sqrt(a-i) ; j++) {
                if((a-i)%j==0)
                {
                    break;
                }
            }
            if(j>Math.sqrt(a-i))
            {
                right=1;
            }
            if(left==1||right==1)
            {
                break;
            }
        }
        if(left==1)
        {
            return a+i;
        }else {
            return a-i;
        }

    }
    public static ArrayList<Integer> list = new ArrayList<Integer>();
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            int n = in.nextInt();
            int len = n;
            while (n-- > 0) {
                int a = in.nextInt();
                // 求最近素数
                int res = makeNearestPrime(a);
                list.add(res);
            }
            for (int i = 0; i < len; i++) {
                System.out.println(list.get(i));
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值