这几天忙项目去啦,课也很多,所以断更了几天。
JZ29最小的K个数
tag:数组[高级算法]
题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4。
解题思路
这个题目较难,可以使用冒泡/堆排/快排等等排序算法,但是我们有比较简便的方法,直接调用Arrays的排序功能,我们再从中筛选就可以了。
代码部分
import java.util.*;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
Arrays.sort(input);
ArrayList<Integer> result = new ArrayList<>();
int i = 0;
if(k>input.length){
return result;
}
while(i<k && k<=input.length){
result.add(input[i]);
i++;
}
return result;
}
}
时间复杂度:O(nlongn)
空间复杂度:O(1)
当然,数据量大的时候这个方法就显得没有那么方便啦,博主之后再来更新更好的方法~🤭
本文介绍了一种使用Java内置排序方法快速找到数组中最小K个数的算法实现,并给出了具体代码示例。

被折叠的 条评论
为什么被折叠?



