思路一:直接使用 Arrays.sort() 对给出的数组进行一个排序,然后取出前 k 个即可。
import java.util.*;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer> list = new ArrayList<>();
if(k > input.length) return list;
Arrays.sort(input);
for(int i = 0; i < k; ++ i) {
list.add(input[i]);
}
return list;
}
} 思路二:手写快排( -ing)
思路三:手写堆排序( -ing)

京公网安备 11010502036488号