题目
输入整数数组 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]
来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/zu… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路
排序 输出前k个 也可以用大顶堆来维护大小为k的最值集合
题解
var getLeastNumbers = function(arr, k) {
let newArr=arr.sort((a,b)=>{
return a-b;
});
let ans=[];
for(let i=0;i<k;i++){
ans.push(newArr[i]);
}
return ans;
};