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入门到精通教程
查看: 614|回复: 0

[算法学习]java 中的优先队列PriorityQueue

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

    [LV.1]初来乍到

    发表于 2014-12-1 00:05:52 | 显示全部楼层 |阅读模式
    优先级队列是不同于先进先出队列的另一种队列。每次从队列中取出的是具有最高优先权的元素。

    PriorityQueue是从JDK1.5开始提供的新的数据结构接口。
         如果不提供Comparator的话,优先队列中元素默认按自然顺序排列,也就是数字默认是小的在队列头,字符串则按字典序排列。


       
         
          
          方法摘要
          
          
          boolean
          add(E e)
    将指定的元素插入此优先级队列。
          
          
          void
          clear()
    从此优先级队列中移除所有元素。
          
          
          Comparator<? super E>
          comparator()
    返回用来对此队列中的元素进行排序的比较器;如果此队列根据其元素的自然顺序进行排序,则返回 null。
          
          
          boolean
          contains(Object o)
    如果此队列包含指定的元素,则返回 true。
          
          
          Iterator<E>
          iterator()
    返回在此队列中的元素上进行迭代的迭代器。
          
          
          boolean
          ofer(E e)
    将指定的元素插入此优先级队列。
          
          
          E
          peek()
    获取但不移除此队列的头;如果此队列为空,则返回 null。
          
          
          E
          poll()
    获取并移除此队列的头,如果此队列为空,则返回 null。
          
          
          boolean
          remove(Object o)
    从此队列中移除指定元素的单个实例(如果存在)。
          
          
          int
          size()
    返回此 collection 中的元素数。
          
          
          Object[]
          toArray()
    返回一个包含此队列所有元素的数组。
          
          
          
            
             
             
              <T> T[]
             
             
            
          toArray(T[] a)
    返回一个包含此队列所有元素的数组;返回数组的运行时类型是指定数组的类型。
          
         
       
    1. import java.io.*;
    2. import java.util.*;
    3. class Point{
    4.     int x;
    5.     int y;
    6.    
    7.     public Point( int x, int y ){
    8.         this.x = x;
    9.         this.y = y;
    10.     }
    11.     public void print(){
    12.         System.out.println( "" + x + " " + y );
    13.     }
    14. }
    15. public class Main{
    16.     public static void main( String [] args )throws Exception{
    17.         
    18.         Scanner cin = new Scanner( System.in );
    19.         
    20.         int n = cin.nextInt();
    21.         
    22.         PriorityQueue queue = new PriorityQueue
    23.    
    24.      ( 1, new Comparator
    25.      
    26.       (){
    27.             public int compare( Point a, Point b ){
    28.                 if( a.x < b.x || a.x == b.x && a.y < b.y ){
    29.                     return -1;
    30.                 }
    31.                 else if( a.x == b.x && a.y == b.y ){
    32.                     return 0;
    33.                 }
    34.                 else{
    35.                     return 1;
    36.                 }
    37.             }
    38.         });
    39.         
    40.         for( int i = 0; i < n; i++ ){
    41.             int x = cin.nextInt();
    42.             int y = cin.nextInt();
    43.             
    44.             Point p = new Point( x, y );
    45.             
    46.             queue.add( p );
    47.         }
    48.         
    49.         while( queue.size() > 0 ){
    50.             Point p = ( Point )queue.poll();
    51.             
    52.             p.print();
    53.         }
    54.     }
    55. }
    56.      
    57.    
    复制代码

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/12/1/000552109.zip
    回复

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2025-2-25 04:47 , Processed in 0.334516 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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