题解 | #最小的K个数#

最小的K个数

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

class Solution {
public:
    vector<int> GetLeastNumbers_Solution(vector<int> input, int k) {
        vector<int > res;
        vector<int> heap = make_heap(input);
        while(k--){
            res.push_back(heap[0]);
            swap(heap[0], heap[heap.size()-1]);
            heap.pop_back();
            down(heap);
        }
        return res;
    }
    vector<int> make_heap(vector<int> input){
        vector<int > heap;
        for(int i = 0; i < input.size(); i++) {
            heap.push_back(input[i]);
            up(heap);
        }
        return heap;
    }
    void up(vector<int>& heap){
        int length = heap.size();
        int i = length - 1;
        while(i){
            int prei = i;
            if(i % 2 == 0){
                if(heap[i] < heap[i/2 - 1]){
                    swap(heap[i], heap[i/2-1]);
                    i = i / 2 - 1;
                }
            }else{
                if(heap[i] < heap[(i-1)/2]){
                    swap(heap[i], heap[(i-1)/2]);
                    i = (i-1) / 2;
                }
            }
            if(prei == i) break;
        }
    }
    void down(vector<int>& heap){
        int length = heap.size();
        int i = 0;
        while(i < length / 2){
            int prei = i;
            int j = 2 * i + 1;
            int k = 2 * (i + 1);
            if(k < length){
                if(heap[j] > heap[k]){
                    j = k; // 保证j最小
                }
            }

            if(heap[i] > heap[j]){
                swap(heap[i], heap[j]);
                i = j;
            }
            if(prei == i) break;
        }
    }
};
全部评论

相关推荐

阿武同学:基本信息保留前面三行,其他的可以全部删掉,邮箱最重要的你没写,主修课程精简到8个以内,实习里面2/3/4都是水内容的,非要写的话建议两到三句话,项目经历排版优化下,自我评价缩到三行
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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