求助!AC 60%

P1923 【深基9.例4】求第 k 小的数

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,所以没记模板,不要学习我(逃


|