Pagini recente » Cod sursa (job #2950384) | Cod sursa (job #2883207) | Cod sursa (job #1442689) | Cod sursa (job #427770) | Cod sursa (job #2616306)
#include<cstdio>
#include<algorithm>
#include<random>
using namespace std;
FILE*in=fopen("sdo.in","r");
FILE*out=fopen("sdo.out","w");
int n,k,v[3000003],i,ct,it1,it2,p=1,x,y;
int main()
{
fscanf(in,"%d%d",&n,&k);
for(i=1;i<=n;i++)
{
fscanf(in,"%d",&v[i]);
}
for(i=1;i<=n;i++)
{
swap(v[i],v[rand()%n+1];
}
x=1;
y=n;
while(p!=k)
{
p=x;
it1=x;
it2=y;
ct=0;
while(it1<=it2)
{
if(ct%2==0)
{
while(v[it2]>v[p])
{
it2--;
}
swap(v[it2],v[p]);
p=it2;
it2--;
}
if(ct%2==1)
{
while(v[it1]<v[p])
{
it1++;
}
swap(v[it1],v[p]);
p=it1;
it1++;
}
ct++;
}
if(p>k)
{
y=p-1;
}
else
{
x=p+1;
}
}
fprintf(out,"%d",v[p]);
}