题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
题目解答
使用小根堆
将n个元素全放进小根堆,再一个一个的弹出来,弹前k个为最小的K个
时间复杂度为O(N)+Klog(N);
import java.util.ArrayList;
import java.util.PriorityQueue;
public class GetLeastNumbersMe {
public static void main(String[] args) {
int[] arr = {4,5,1,6,2,7,3,8};
GetLeastNumbersMe me = new GetLeastNumbersMe();
ArrayList<Integer> list = me.GetLeastNumbers_Solution(arr,5);
System.out.println(list.toString());
}
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer>list=new ArrayList<>();
if(k>input.length||k==0)
return list;
PriorityQueue<Integer> minStack=new PriorityQueue<>();
for(int i=0,len=input.length;i<len;i++){
minStack.add(input[i]);
}
for(int i=0;i<k;i++){
list.add(minStack.poll());
}
return list;
}
}