最小的K个数(java)

题目描述

输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。

分析:

找出最小的K个数字,可以通过维护一个大根堆来实现最小的K个数字,当大根堆的个数大于K的时候,把堆顶元素去掉,从而保证大根堆的大小为k。
同样,也可以通过使用冒泡排序算法,每次排序得到最小的数字的一个位置。这样就可以实现不用全部排序也可以得到最小的四个数字。

又是一道简单题,就不进行详细的分解了。

解答:

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
        ArrayList<Integer> leastk = new ArrayList<Integer>();
        if(input==null || input.length==0 || input.length<k) return leastk;
        for(int i =0;i<k;i++) {
            //冒泡排序,每次排序过程确定一个最小值
            for(int j = input.length-1;j>i;j--){
                if (input[j - 1] > input[j]) { //交换,把小的顶到前面去
                    int temp = input[j];
                    input[j] = input[j - 1];
                    input[j - 1]= temp;
                }
            }
            leastk.add(input[i]);
        }
        return leastk;
    }
}

运行结果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 概述排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的...
    Luc_阅读 2,372评论 0 35
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,826评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,301评论 0 52
  • 鸥鸟忘机矣?算如今、海翁遗恨,早消风里。人道功名羞才尽,我道谁人不是?玉珂下,几个高士?书社蛛尘君莫扫,料雕虫、笑...
    高天洁雨18阅读 252评论 1 1
  • 监狱风云中有众多老大,张耀扬饰演的杀手雄最不敢惹的就是潮州佬,就算他将饭倒掉,也拿他没有办法。潮州佬的扮演者是韩坤...
    电影聚焦阅读 4,380评论 0 2

友情链接更多精彩内容