Pagini recente » Cod sursa (job #2080342) | Cod sursa (job #2511728) | Cod sursa (job #2202856) | Cod sursa (job #1393124) | Cod sursa (job #645766)
Cod sursa(job #645766)
#include<stdio.h>
#include<cstdlib>
int a[3000001],n,k;
void citire(){
scanf("%d%d",&n,&k);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
}
int pivot(int i,int j){
int p=a[i+(rand()%(j-i+1))];
while(i<j){
while(a[i]<p)
i++;
while(a[j]>p)
j--;
a[i]=a[i]^a[j]^(a[j]=a[i]);
}
return i;
}
void qsort1(int i,int j,int k){
int p=pivot(i,j);
if(k==p)
return;
else
if(k>=p)
qsort1(p+1,j,k);
else
qsort1(i,p-1,k);
}
int main(){
freopen("sdo.in","r",stdin);
freopen("sdo.out","w",stdout);
citire();
qsort1(1,n,k);
printf("%d",a[k]);
return 0;
}