Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 375|回复: 0

[算法学习]利用有序队列寻找最大的K个数

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-10 00:02:23 | 显示全部楼层 |阅读模式
    这是一个很常见的算法问题,从一组数中选出最大的K个。
          《编程之美》上也有这个问题的一些解法。其中,一种较好的解法就是利用有序队列(如java中的PriorityQueue),主要的算法思路如下:
       先从第一个数开始,依次入队k个数,此时,有序队列以对这k个数排序完成,按照从小(队列首)到大(队列尾)顺序排列。 然后,依次遍历后面的剩余数字,当队列首小于即将入队的数时,出队,并将当前的数入队。如此重复,直到遍历完毕。
    此时,队列中剩下的即是最大的K个数了。
    具体范例如下,使用JAVA编写。
          
    /**
    * @(#)Kmax.java
    *
    * Kmax application
    *
    * @author   
    * @version 1.00 2010/2/19
    */
          

          import
          static java.lang.System.out;
          

          import java.util.Comparator;
          

          import java.util.PriorityQueue;
          

          

          class MyComparator
          implements Comparator {
          
       
          public
          int compare(Object a, Object b) {
          
         
          return ((Long)a).compareTo((Long)b);
          
       }
          
    }
          

          

          public
          class Kmax {
          
             
          private
          long []n;
          
             
          private
          int maxNum = 20;
          
             
          private
          int k = 5;
          
             
          private
          final
          static
          int BOUND = 1000;
          
             
          
             
          private
          void generateNumbers() {
          
               n =
          new
          long[maxNum];
          
               
          for(
          int i = 0; i < maxNum; i++) {
          
                 n = Math.round(Math.random() * BOUND);
          
                 out.println(n);
          
               }
          
             }
          

          
             
          private
          void selectKmax() {
          
               PriorityQueue pq =
          new PriorityQueue(k,
          new MyComparator());
          
               
          for(
          int i = 0; i < k; i++) {
          
                 pq.offer(n);
          
               }
          
                
          
               
          for(
          int i = k; i < maxNum; i++) {   
          
                
          if(n > (Long)pq.peek()) {
          
                   pq.poll();
          
                   pq.offer(n);
          
                 }
          
               }
          
                
          
               out.println(
          "-----------------------");
          
               
          while(pq.size() > 0) {
          
                 out.println((Long)pq.poll());
          
               }
          
             }
          
             
          
             
          public
          static
          void main(String[] args) {
          
               Kmax kmax =
          new Kmax();
          
               kmax.generateNumbers();
          //产生maxNum个随机整数
          
               kmax.selectKmax();
          //从中选出k个最大的数,并输出
          
               out.println(
          "Complete!");
          
             }
          
    }
          

          
         
       
          运行结果:
         

         
    C:at>java
         
    303
         
    868
         
    903
         
    678
         
    241
         
    946
         
    872
         
    810
         
    281
         
    703
         
    796
         
    75
         
    593
         
    866
         
    850
         
    557
         
    74
         
    224
         
    400
         
    717
         
    -------------
         
    866
         
    868
         
    872
         
    903
         
    946
         
    Complete!
         
       
         这个算法速度较快,是一种极好的解法。
         
        本文出自 “Kevx"s Blog” 博客,请务必保留此出处http://spinlock.blog.51cto.com/607469/277124
       
       

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/11/10/000223531.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 07:41 , Processed in 0.363639 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表