输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4。
最小的K个数
http://www.nowcoder.com/questionTerminal/6a296eb82cf844ca8539b57c23e6e9bf
import java.util.*; public class Solution { public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) { if (input == null || input.length == 0 || k == 0 || input.length < k) { return new ArrayList<>(); } ArrayList<Integer> res = new ArrayList<>(); int start = 0, end = input.length - 1; int index = partition(input, start, end); while (index != k - 1) { if (index < k - 1) { start = index + 1; } else { end = index - 1; } index = partition(input, start, end); } for (int i = 0; i <= index; i++) { res.add(input[i]); } return res; } private static int partition(int[] input, int start, int end) { int pivot = input[start]; while (start < end) { while (start < end && input[end] >= pivot) { end--; } swap(input, start, end); while (start < end && input[start] < pivot) { start++; } swap(input, start, end); } return start; } private static void swap(int[] input, int left, int right) { int tmp = input[left]; input[left] = input[right]; input[right] = tmp; } }