原题链接:第K极值
#include<stdio.h>
#include"malloc.h"
#include"math.h"
int sort(int a[],int n,int k);
int func(int n);
int main()
{
int n,k,i,sub;
scanf("%d%d",&n,&k);
int *pt=(int*)malloc(n*sizeof(int));
for(i=0;i<n;i++)
scanf("%d",&pt[i]);
sub=sort(pt,n,k);
if(func(sub)) printf("YES\n%d\n",sub);
else printf("NO\n%d\n",sub);
return 0;
}
int sort(int a[],int n,int k)
{
int i,j,temp;
//int c1=0,c2=0,min_k,max_k;
for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
if(a[i]>a[j])
{temp=a[i];a[i]=a[j];a[j]=temp;}
/* for(i=0;i<n-1;i++) 同样的数同一个大小等级
{
if(a[i]!=a[i+1]) c1++;
if(c1==k)
{
min_k=a[i];
break;
}
}
for(i=n-1;i>0;i--)
{
if(a[i]!=a[i-1]) c2++;
if(c2==k)
{
max_k=a[i];
break;
}
}*/
return a[n-k]-a[k-1];
}
int func(int n)
{
int i=2,flag=1;
if(n<=1) flag=0; 对于小于2的数直接NO
else
{
for(;i<=sqrt(n);i++)
if(n%i==0)
flag=0;
}
return flag;
} 0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复