Secret_Sky_2021 @ 2023-08-26 15:30:42
#include<iostream>
#include<algorithm>
#include<ctime>
using namespace std;
const int N=5000100;
int n,m,a[N];
int qs(int i,int j){
srand(time(0));
int key=a[(rand()%(j-i+1))+i];
while(i<j){
while(i<j&& a[j]>=key) j--;
if(i<j) a[i]=a[j];
while(i<j&& a[i]<=key) i++;
if(i<j) a[j]=a[i];
}
a[i]=key;
return i;
}
int find(int left, int right, int k)
{
int tem=qs(left,right);
if(k==tem) printf("%d",a[k]);
else if(k-1<tem) find(left,tem-1,k);
else find(tem+1,right,k);
return 0;
}
int main(){
cin>>n>>m;
for(int i=0;i<n;i++) scanf("%d",&a[i]);
find(0,n-1,m);
return 0;
}
/*
5 1
4 3 2 1 5
---------
2
*/
by Max6700 @ 2023-08-26 15:37:47
@Alexlin1224 %%%,我是开同步流+sort过的QωQ
by Secret_Sky_2021 @ 2023-08-26 15:43:35
@Max6700 老师要求用快排写TT我抄袭借鉴了大佬的题解写的
by Max6700 @ 2023-08-26 15:45:21
@Alexlin1224 sort就是c++自带快排
咳咳,很荣幸 我的做法和你“借鉴”的题解的第一个做法一样
by Max6700 @ 2023-08-26 15:45:43
@Alexlin1224 你可以去网上搜一下c++快排模板
by Max6700 @ 2023-08-26 15:46:55
@Alexlin1224 我都是直接用sort,所以没记模板,不要学习我(逃