洛谷P1923 【深基9.例4】求第 k 小的数(java)

java 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.StreamTokenizer;
import java.util.Arrays;
import java.util.Scanner;
//输入n个数字ai,输出这些数字的第k小的数。最小的数是第0小。
public class Main {

    public static void main(String[] args) throws IOException {
        StreamTokenizer sc = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        sc.nextToken();
        int n = (int) sc.nval;
        sc.nextToken();
        int k = (int) sc.nval;
//        Scanner sc = new Scanner(System.in);
//        int n = sc.nextInt();//n个数
//        int k = sc.nextInt();//第k小的数
        int a[] = new int[n];
        for (int i = 0; i < n; i++) {
            sc.nextToken();
            a[i] = (int) sc.nval;
        }

        for (int i = 0; i < a.length; i++) {
            for (int j = i; j < a.length; j++) {

            }
        }
        //Quick_sort(a, 0, a.length - 1);
        //System.out.println(a[k]);o(nlogn)
        int i = find(a, 0, a.length - 1, k);

    }
     public static int find (int[] a,int left, int right, int k)
    {	//在数组a的第left到right中寻找第k小的数
        int tem=Partition(a,left,right);
        if(k==tem)
            System.out.println(a[k]);
        else if(k-1<tem)//判断下一次划分在哪一区间进行
            find(a,left,tem-1,k);
        else
            find(a,tem+1,right,k);
        return 0;
    }

    public static void Quick_sort(int[] a, int low, int high) {
        if (low < high) {
            int p = Partition(a, low, high);
            Quick_sort(a, low, p - 1);
            Quick_sort(a, p + 1, high);
        }

    }

    public static int Partition(int[] a, int low, int high) {
        int pivot = a[low];//pivot 支点;中心
        while (low < high) {
            while (low < high && a[high] >= pivot)
                high--;
            a[low] = a[high];
            while (low < high && a[low] <= pivot) low++;
            a[high] = a[low];
        }
            a[low] = pivot;
            return low;//return high
    }
}
相关推荐
希忘auto4 分钟前
Spring Cloud之注册中心之Nacos的安装
java·后端·spring·spring cloud
请卧龙先生出山9 分钟前
c++day4
开发语言·c++
愚戏师13 分钟前
从零到一学习c++(基础篇--筑基期十一-类)
开发语言·数据结构·c++·学习·算法
thinkMoreAndDoMore34 分钟前
python与C系列语言的差异总结(2)
java·c语言·python
郑祎亦43 分钟前
Java String 类
java·开发语言·python
一直走下去-明1 小时前
next.js-学习2
开发语言·javascript·学习
无世世1 小时前
【Java从入门到起飞】面向对象编程(入门)
java·开发语言
笨手笨脚の1 小时前
以 Tomcat 为例分析 Java 中的线程池
java·开发语言·tomcat·线程池·拒绝策略
周周记笔记1 小时前
R与RStudio简介及安装
开发语言·r语言
冬天vs不冷1 小时前
SpringBoot源码解析(十一):准备应用上下文
java·spring boot·spring