私信TA

用户名:Praguetramp

访问量:30978

签 名:

等  级
排  名 20
经  验 20194
参赛次数 0
文章发表 130
年  龄 0
在职情况 待业
学  校
专  业

  自我简介:

aura

解题思路:  无

注意事项:  注意存在差为0,1的特殊值时,

输入:

5 2

2 2 2 2 2   

输出 :

NO

0


输入:
5 2

2 2 2 3 3

输出:

NO

1
参考代码:

import java.util.Arrays;
import java.util.Scanner;
public class Main {
	public static void main(String []args) {
		Scanner in =new Scanner(System.in);
		int n=in.nextInt(),k=in.nextInt();
		int arr[]= new int[n];
		for(int i=0;i<n;i++)
			arr[i]=in.nextInt();
		Arrays.sort(arr);
		int tmp=arr[n-k]-arr[k-1];
		boolean flag=true;
		if(tmp<2)
			flag=false;   //注意处理特殊情况
		for(int i=2;i<=Math.sqrt(tmp);i++) {  //判断素数
			if(tmp%i==0) {
				flag=false;
				break;
			}
		}
		if(flag)
			System.out.println("YES");
		else
			System.out.println("NO");
		System.out.println(tmp);
		in.close();
	}
}


 

0.0分

2 人评分

  评论区

不考虑特殊情况就只有73分,就这一个特殊条件就满分了。
2021-10-19 20:19:05
  • «
  • 1
  • »