leetcode刷题33.最小的k个数——Java版

Posted 一条coding

tags:

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

⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐

先找到第k小的数,然后遍历一遍数组,把所有比k小的数加入结果集。然后用这个数填充结果集,使结果集大小等于k。

——leetcode此题热评

前言

哈喽,大家好,我是一条。

糊涂算法,难得糊涂

今天给大家推荐一位字节算法大佬,ACM队长——「英雄哪里出来」

Question

剑指 Offer 40. 最小的k个数

难度:简单

输入整数数组 arr ,找出其中最小的 k 个数。例如,输入4、5、1、6、2、7、3、8这8个数字,则最小的4个数字是1、2、3、4。

示例 1:

输入:arr = [3,2,1], k = 2
输出:[1,2] 或者 [2,1]

示例 2:

输入:arr = [0,1,2,1], k = 1
输出:[0]

限制:

0 <= k <= arr.length <= 10000
0 <= arr[i] <= 10000

Solution

该题是比较经典的TopK问题,解决的办法通常可以用快排、堆、二叉搜索树、计数排序。本文采用快速排序的方法,因为最高效。

快速排序:说白了就是给基准数据找其正确索引位置的过程.

根据快速排序原理,如果某次哨兵划分后 基准数正好是第 k+1小的数字 ,那么此时基准数左边的所有数字便是题目所求的 最小的 k 个数

Code

所有leetcode代码已同步至github

欢迎star

/**
 * @author yitiaoIT
 */
class Solution {
    public int[] getLeastNumbers(int[] arr, int k) {
        if (k >= arr.length) return arr;
        return quickSort(arr, k, 0, arr.length - 1);
    }
    private int[] quickSort(int[] arr, int k, int l, int r) {
        int i = l, j = r;
        while (i < j) {
            while (i < j && arr[j] >= arr[l]) j--;
            while (i < j && arr[i] <= arr[l]) i++;
            swap(arr, i, j);
        }
        swap(arr, i, l);
        if (i > k) return quickSort(arr, k, l, i - 1);
        if (i < k) return quickSort(arr, k, i + 1, r);
        return Arrays.copyOf(arr, k);
    }
    private void swap(int[] arr, int i, int j) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }
}

Result

复杂度分析

  • 时间复杂度:O(N)

🌈寻宝

⭐今天是坚持刷题更文的第33/100天

⭐各位的点赞、关注、收藏、评论、订阅就是一条创作的最大动力

⭐更多算法题欢迎关注专栏《leetcode》

为了回馈各位粉丝,礼尚往来,给大家准备了一条多年积累下来的优质资源,包括 学习视频、面试资料、珍藏电子书等

大家可以先自己找一下获取方式,寻宝游戏现在开始。

如果实在找不到可以评论区留言或私信我领取,不过一定要先关注哦!不然无法发私信!

以上是关于leetcode刷题33.最小的k个数——Java版的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode刷题100天—面试题 17.14. 最小K个数(优先队列)—day27

LeetCode刷题 剑指 Offer 40-简单-最小的k个数

LeetCode刷题面试题17.14-简单-最小k个数

LeetCode刷题面试题17.14-简单-最小k个数

LeetCode刷题(130)~前 K 个高频元素最小堆|快速排列 难点!

Leetcode刷题100天—373. 查找和最小的K对数字(优先队列)—day17