1.题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
2.思路分析
将数组排序,然后再找出前最小的K个数
3.代码展示
import java.util.List;
import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
if(input.length < k){
return new ArrayList<>();
}
//冒泡排序
for(int i=0;i<input.length;i++){
for(int j=0;j<input.length-i-1;j++){
if(input[j] > input[j+1]){
int temp = input[j];
input[j] = input[j+1];
input[j+1] = temp;
}
}
}
ArrayList<Integer> list = new ArrayList<>();
for(int i=0;i<k;i++){
list.add(input[i]);
}
return list;
}
}
不过这肯定不是最佳解决方法,回头再来更新