Java的优先队列PriorityQueue原理及实例分析

 更新时间:2019年12月25日 10:09:19   作者:番茄_Morgan  
这篇文章主要介绍了Java的优先队列PriorityQueue原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了Java的优先队列PriorityQueue原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一、优先队列概述

优先队列PriorityQueue是Queue接口的实现,可以对其中元素进行排序,

可以放基本数据类型的包装类(如:Integer,Long等)或自定义的类

对于基本数据类型的包装器类,优先队列中元素默认排列顺序是升序排列

但对于自己定义的类来说,需要自己定义比较器

二、常用方法

  • peek()//返回队首元素
  • poll()//返回队首元素,队首元素出队列
  • add()//添加元素
  • size()//返回队列元素个数
  • isEmpty()//判断队列是否为空,为空返回true,不空返回false

三、优先队列的使用

1.队列保存的是基本数据类型的包装类

//自定义比较器,降序排列
static Comparator<Integer> cmp = new Comparator<Integer>() {
  public int compare(Integer e1, Integer e2) {
  return e2 - e1;
  }
 };
public static void main(String[] args) {
  //不用比较器,默认升序排列
  Queue<Integer> q = new PriorityQueue<>();
  q.add(3);
  q.add(2);
  q.add(4);
  while(!q.isEmpty())
  {
   System.out.print(q.poll()+" ");
  }
  /**
   * 输出结果
   * 2 3 4 
   */
  //使用自定义比较器,降序排列
  Queue<Integer> qq = new PriorityQueue<>(cmp);
  qq.add(3);
  qq.add(2);
  qq.add(4);
  while(!qq.isEmpty())
  {
   System.out.print(qq.poll()+" ");
  }
  /**
   * 输出结果
   * 4 3 2 
   */
}

2.队列保存的是自定义类

//矩形类
class Node{
 public Node(int chang,int kuan)
 {
  this.chang=chang;
  this.kuan=kuan;
 }
 int chang;
 int kuan;
}

public class Test {
    //自定义比较类,先比较长,长升序排列,若长相等再比较宽,宽降序
 static Comparator<Node> cNode=new Comparator<Node>() {
  public int compare(Node o1, Node o2) {
   if(o1.chang!=o2.chang)
    return o1.chang-o2.chang;
   else
    return o2.kuan-o1.kuan;
  }
  
 };
 public static void main(String[] args) {
  Queue<Node> q=new PriorityQueue<>(cNode);
  Node n1=new Node(1, 2);
  Node n2=new Node(2, 5);
  Node n3=new Node(2, 3);
  Node n4=new Node(1, 2);
  q.add(n1);
  q.add(n2);
  q.add(n3);
  Node n;
  while(!q.isEmpty())
  {
   n=q.poll();
   System.out.println("长: "+n.chang+" 宽:" +n.kuan);
  }
     /**
      * 输出结果
      * 长: 1 宽:2
      * 长: 2 宽:5
      * 长: 2 宽:3
      */
 }
}

3.优先队列遍历

  PriorityQueue的iterator()不保证以任何特定顺序遍历队列元素。

  若想按特定顺序遍历,先将队列转成数组,然后排序遍历

示例

Queue<Integer> q = new PriorityQueue<>(cmp);
  int[] nums= {2,5,3,4,1,6};
  for(int i:nums)
  {
   q.add(i);
  }
  Object[] nn=q.toArray();
  Arrays.sort(nn);
  for(int i=nn.length-1;i>=0;i--)
   System.out.print((int)nn[i]+" ");
  /**
   * 输出结果
   * 6 5 4 3 2 1 
   */

4.比较器生降序说明

Comparator<Object> cmp = new Comparator<Object>() {
  public int compare(Object o1, Object o2) {
   //升序
   return o1-o2;
   //降序
   return o2-o1;
  }
 };

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring Cloud Stream整合RocketMQ的搭建方法

    Spring Cloud Stream整合RocketMQ的搭建方法

    本文介绍了如何使用SpringCloudStream整合RocketMQ进行消息传递,SpringCloudStream是一个用于构建与共享消息系统连接的框架,支持持久pub/sub语义和消费者组,感兴趣的朋友跟随小编一起看看吧
    2024-11-11
  • springboot从application.properties中注入list, map方式

    springboot从application.properties中注入list, map方式

    这篇文章主要介绍了springboot从application.properties中注入list,map方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Intellij IDEA的一些调试技巧(小结)

    Intellij IDEA的一些调试技巧(小结)

    本篇文章主要介绍了Intellij IDEA的一些调试技巧(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • java技巧:反射判断field类型的操作

    java技巧:反射判断field类型的操作

    这篇文章主要介绍了java技巧:反射判断field类型的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • resty client使用Java客户端来访问Api

    resty client使用Java客户端来访问Api

    这篇文章主要介绍了resty-client使用Java客户端来访问Api的验证权限,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • java微信开发API第一步 服务器接入

    java微信开发API第一步 服务器接入

    这篇文章主要为大家分享了java微信开发API的第一步操作服务器接入,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • 利用java监听器实现在线人数统计

    利用java监听器实现在线人数统计

    过去使用ASP和ASP.NET两种编程的时候,都写过在线人数统计能,实现功能挺简单的!今天使用java来实现在线人数统计有点另类,是通过Java监听器实现的,需要的朋友可以参考下
    2015-09-09
  • Java webSerivce的使用看完你就明白了

    Java webSerivce的使用看完你就明白了

    因为前段时间,需要使用到webService来调用公司的其他系统api接口,但是请求方式和我熟知的http请求不一样,是基于soap协议来传输xml数据格式,请求的参数极其复杂,需要封装多层xml数据格式,并且我不知道对方的api接口是什么语言,甚至不知道他们存在于什么平台
    2022-03-03
  • springboot2 jackson实现动态返回类字段方式

    springboot2 jackson实现动态返回类字段方式

    这篇文章主要介绍了springboot2 jackson实现动态返回类字段方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • 浅谈java字符串比较到底应该用==还是equals

    浅谈java字符串比较到底应该用==还是equals

    这篇文章主要介绍了浅谈java字符串比较到底应该用==还是equals,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12

最新评论