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; } }