题解 | #最小的K个数#

最小的K个数

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

import java.util.ArrayList;

public class Solution {

    public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
        ArrayList<Integer> res = new ArrayList<>(k);
        int len = input.length;
        for(int i = len/2 - 1;i >= 0; --i) {
            adjust(input,i,len);
        }
        for(int i = len-1; i >= len -k; --i) {
            res.add(input[0]);
            swap(input,0,i);
            adjust(input,0,i);
        }

        return res;



    }
    // 找出最小的k个数
    void adjust(int[] arr, int pos, int end) {
        int child = 2*pos + 1;
        int tmp = arr[pos];
        for(int k = 2*pos + 1; k < end; k = 2*k + 1){
            if(k+1 < end && arr[k+1] < arr[k]) {
                k++;
            }
            if( k < end && arr[k] < tmp) {
                arr[pos] = arr[k];
                pos = k;
            }else {
                break;
            }

        }
        arr[pos] = tmp;
    }

    void swap(int[] arr,int i, int j) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }

    // 找出最大的k个数
    void adjust2(int[] arr, int pos, int end) {
        int child = 2*pos + 1;
        int tmp = arr[pos];
        for(int k = 2*pos + 1; k < end; k = 2*k + 1){
            if(k+1 < end && arr[k+1] > arr[k]) { // 修改
                k++;
            }
            if( k < end && arr[k] > tmp) {   // 修改
                arr[pos] = arr[k];
                pos = k;
            }else {
                break;
            }

        }
        arr[pos] = tmp;
    }


}
全部评论

相关推荐

05-30 12:03
山西大学 C++
offer来了我跪着接:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
白火同学:大二有这水平很牛了,可以适当对关键信息加粗一点,比如关键技术、性能指标之类的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务