第k个数(排序)

Posted qdu_lkc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第k个数(排序)相关的知识,希望对你有一定的参考价值。

给定一个长度为n的整数数列,以及一个整数k,请用快速选择算法求出数列的第k小的数是多少。

输入格式

第一行包含两个整数 n 和 k。

第二行包含 n 个整数(所有整数均在1~109109范围内),表示整数数列。

输出格式

输出一个整数,表示数列的第k小数。

数据范围

1n1000001≤n≤100000,
1kn1≤k≤n

输入样例:

5 3
2 4 1 5 3

输出样例:

3

快速排序,时间O(n*logn)
       import java.util.Scanner;

       public class Main {
           public static void quick_sort(int a[],int l,int r){
                 if(l>=r) return;
                 int i=l-1,j=r+1,x=a[l+r>>1];
                 while(i<j){
                       while(a[++i]<x);
                       while(a[--j]>x);
                       if(i<j){
                           int t=a[i];
                           a[i]=a[j];
                           a[j]=t;
                       }
                 }
                 quick_sort(a,l,j);
                 quick_sort(a,j+1,r);
           }
           public static void main(String[] args) {
                Scanner scan=new Scanner(System.in);
                int n=scan.nextInt();
                int k=scan.nextInt();
                int a[]=new int[n];
                for(int i=0;i<n;i++) a[i]=scan.nextInt();
                quick_sort(a,0,n-1);
                System.out.println(a[k-1]);
        }
}

以上是关于第k个数(排序)的主要内容,如果未能解决你的问题,请参考以下文章

第k个数(排序)

将一个整数数组先按照因子数量排序,再按照数字大小排序,输出第k个数

Acwing 785. 快速排序/AcWing 786. 第k个数

尺取法

关于排序的相关代码(数据结构笔试复测Leecode牛客)

找到排序矩阵中从小到大第K个数字