1.题目:
给定一个数组,找出其中最小的K个数。例如数组元素是4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4。如果K>数组的长度,那么返回一个空的数组
输入:[4,5,1,6,2,7,3,8],4 输出:[1,2,3,4]
2.思路:
先排序,再取出,具体时间复杂度取决于排序算法
import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer> list=new ArrayList<>();
int len=input.length;
if(k>len) return list;
//1.先排序,此处采用冒泡排序,可以选择其他排序方法
for(int i=0;i<len-1;i++){
for(int j=0;j<len-i-1;j++){
if(input[j]>input[j+1]){
int temp=input[j];
input[j]=input[j+1];
input[j+1]=temp;
}
}
}
//2.再遍历取出入ArrayList
for(int n=0;n<k;n++){
list.add(input[n]);
}
return list;
}
}
京公网安备 11010502036488号