题解 | #最小的K个数#

最小的K个数

http://www.nowcoder.com/practice/6a296eb82cf844ca8539b57c23e6e9bf

排序,输出k个数即可

import java.util.*;

public class Solution {
    public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
        Arrays.sort(input);
        ArrayList<Integer> ret = new ArrayList<>();
        int cnt = 0;
        int idx = 0;
        while(cnt < k){
            ret.add(input[idx++]);
            cnt++;
        }
        return ret;
    }
}

手写的快排

import java.util.*;

public class Solution {
    public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
        quick_sort(input,0,input.length - 1);
        ArrayList<Integer> ret = new ArrayList<>();
        int cnt = 0;
        int idx = 0;
        while(cnt < k){
            ret.add(input[idx++]);
            cnt++;
        }
        return ret;
    }
    
    public void quick_sort(int arr[],int l,int r){
        if(l >= r)return;
        int i = l - 1,j = r + 1;
        int mid = arr[l + r >> 1];
        while(i < j){
            do{
               i++;
            }while(arr[i] < mid);
            do{
                j--;
            }while(arr[j] > mid);
            if(i < j){
                int tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
            }
        }
        quick_sort(arr,l,j);
        quick_sort(arr,j + 1,r);
    }
    
}
全部评论

相关推荐

11-01 08:48
门头沟学院 C++
伤心的候选人在吵架:佬你不要的,能不能拿户口本证明过户给我。。球球了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务