原题链接:第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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复