题目:输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
思路:可以使用排序 这里我采用快排,获取到一个有顺序的数组,然后获取它的前N个
先使用快排排序
public static void quickSort(int[] arr, int start, int end) {
//当开始位置小于结束位置时(数组有数据) 进行排序 也就是递归入口
if (start < end) {
//首先找到基准数 作为比较的标准数 取数组开始位置 从哪里开始 用哪个数当标准数 这个就是标准数
int stard = arr[start];
//记录需要进行排序的下标 此处指的是游标卡尺的下表
int low = start;
int high = end;
//循环比对比标准数大和小的数字
while (low < high) {
//如果标准数小于右边的数字 把右边的游标卡尺向左移动
while (low < high && stard <= arr[high]) {
high--;
}
//如果标准数大于 右边的数字
//用低位数字替换右边数字
arr[low] = arr[high];
//如果左边的数字比标准数小
while (low < high && arr[low] <= stard) {
low++;
}
//如果左边的数字比标准数大
//用左边数字替换右边数字
arr[high] = arr[low];
}
//把标准数赋给高或者低所在的元素
arr[low] = stard;
//处理所有比标准数小的数字
quickSort(arr, start, low);
//处理所有比标准数大的数字
quickSort(arr, low + 1, end);
}
}
获得一个有序数组之后,获取前N个
public static void main(String[] args) {
int[] arr = new int[]{5, 3, 4, 1, 6, 322, 66, 2, 78};
System.out.println(arr.length);
quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
//获取最小的前5(N)个数字
arr = Arrays.copyOfRange(arr, 0, 5);
System.out.println(Arrays.toString(arr));
}