输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个。
本题最佳的应该是使用堆排序来做,其次是快排的思想来做。
如果题目换成求第K小的数,应是快排的思想最优。
import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer> arrayList = new ArrayList<Integer>();
if(input == null || input.length < k) {
return arrayList;
}
Arrays.sort(input);
for(int i=0;i<k;i++) {
arrayList.add(input[i]);
}
return arrayList;
}
}
数字,则最小的4个数字是1,2,3,4,。