第k个数打卡
作者:
丶123
,
2021-07-10 11:50:09
,
所有人可见
,
阅读 197
#include<iostream>
using namespace std;
const int N = 100010;
int q[N];
int n,k;
int quick_sort(int l,int r)
{
if(l>=r) return q[l];
int x = q[l+r>>1],i=l-1,j=r+1;
while(i<j)
{
do i++;while(q[i] < x);
do j--;while(q[j] > x);
if(i<j) swap(q[i],q[j]);
}
int sl = j-l+1;
if(k<=sl) return quick_sort(l,j);
else
{
k = k-sl;
return quick_sort(j+1,r);
}
}
int main()
{
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++) cin >> q[i];
cout << quick_sort(0,n-1);
return 0;
}