解题思路:
此题容易超内存,所以开大小为2k的数组,每次将数组填满(m>2k时),快排,将最小的前k个数维持在前k个位置;
将剩余的数据陆续填充到后k个位置,重复上述操作。
#include<iostream>
#include<cstdlib>
#include<cstdio>
using namespace std;
int cmp(const void * a,const void * b)
{
return *(int *)a - *(int *)b;
}
int num[200010];
int main()
{
int m,k;
scanf("%d%d",&m,&k);
for(int i=0;i<k;i++)
scanf("%d",&num[i]);
m -= k;
qsort(num,k,sizeof(num[0]),cmp);
while(m>0)
{
if(m>=k)
{
for(int i=k;i<2*k;i++)
scanf("%d",&num[i]);
m -= k;
qsort(num,2*k,sizeof(num[0]),cmp);
}
else
{
for(int i=k;i<k+m;i++)
scanf("%d",&num[i]);
qsort(num,k+m,sizeof(num[0]),cmp);
m = 0;
}
}
printf("%d\n",num[k-1]);
return 0;
}