解题思路:用sort排序解题
注意事项: 注意但m<2时,不能进入for循环判断,会默认为质数
参考代码:
#include<iostream>
#include <algorithm>
using namespace std;
int a[10005];
int main(){
int n,k;
scanf("%d %d",&n,&k);
for(int i=0;i<n;i++){
cin>>a[i];
}
sort(a,a+n);
int max,min;
max=a[n-k];
min=a[k-1];
int m=max-min;
int flag=0;
for(int i=2;i*i<=m;i++){
if(m%i==0){//不是质数
flag=1;
break;
}
}
if(flag==0&&m>=2){//////特别注意&&m>=2
printf("YES\n");
}
else printf("NO\n");
printf("%d\n",m);
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:1292 |
Tom数 (C语言代码)浏览:581 |
分糖果 (C语言代码)浏览:980 |
数列有序 (C语言代码)浏览:974 |
小O的乘积 (C语言代码)浏览:1062 |
C二级辅导-公约公倍 (C语言代码)浏览:693 |
C语言训练-百钱百鸡问题 (C语言代码)浏览:541 |
C语言程序设计教程(第三版)课后习题4.9 (Java代码)浏览:629 |
C语言程序设计教程(第三版)课后习题11.1 (C++代码)浏览:709 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:468 |