美文网首页
Queue的使用、priority_queue优先队列

Queue的使用、priority_queue优先队列

作者: 暑水 | 来源:发表于2019-06-26 15:07 被阅读0次

1、Queue的使用(FIFO)(使用LinkedList实现)

  • Queue使用时要尽量避免Collection的add()和remove()方法,而是要使用offer()来加入元素,使用poll()来获取并移出元素。
  • 它们的优点是通过返回值可以判断成功与否,add()和remove()方法在失败的时候会抛出异常。
  • 如果要使用前端而不移出该元素,使用element()或者peek()方法。

  • 注意:LinkedList类实现了Queue接口,因此我们可以把LinkedList当成Queue来用。

import java.util.Queue;  
import java.util.LinkedList;  
public class TestQueue {  
    public static void main(String[] args) {  
        Queue<String> queue = new LinkedList<String>();  
        queue.offer("Hello");  
        queue.offer("World!");  
        queue.offer("你好!");  
        System.out.println(queue.size());  
        String str;  
        while((str=queue.poll())!=null){  
            System.out.print(str);  
        }  
        System.out.println();  
        System.out.println(queue.size());  
    }  
} 

java中queue的使用
  • Queue接口与List,Set同一级别,都是继承了Collection接口。
  • LinkedList实现了Queue接口。Queue接口窄化了对LinkedList的方法的访问权限(即在方法中的参数类型如果是Queue时,就完全只能访问Queue接口所定义的方法了,而不能直接访问LinkedList的非Queue的方法),以使得只有恰当的方法才可以使用。BlockingQueue继承了Queue接口。

队列是一种数据结构,它有两个基本操作:在队列尾部加入一个元素,和从队列头部移除一个元素。就是说,队列以一种先进先出的方式管理数据,如果你试图向一个已经满了的阻塞队列中添加一个元素或者从一个空的阻塞队列中移除一个元素,将导致线程阻塞。在多线程进行合作时,阻塞队列是很有用的工具。工作者线程可以定期地把中间结果存到阻塞队列中,而其他工作者线程把中间结果取出并将来修改它们。队列会自动平衡负载。如果第一个线程集运行得比第二个慢,则第二个线程集在等待结果时就会阻塞。如果第一个线程集运行得快,那么它将等待第二个线程集赶上来。

2、priority_queue优先队列(非FIFO,小顶堆升序,使用数组顺序实现)

  • 优先队列是队列的一种,优先队列中元素默认排列顺序是升序排列,不过它可以按照自定义的一种方式(数据的优先级)来对队列中的数据进行动态的排序,需要自己定义比较器
  • 每次的push和pop操作,队列都会动态的调整,以达到我们预期的方式来存储。
  • 例如:我们常用的操作就是对数据排序,优先队列默认的是数据大的优先级高
    所以我们无论按照什么顺序push一堆数,最终在队列里总是top出最大的元素。(默认使用小顶堆实现)
比较器升降序说明
Comparator<Object> cmp = new Comparator<Object>() {
        public int compare(Object o1, Object o2) {
            //升序
            return o1-o2;
            //降序
            return o2-o1;
        }
    };

自定义降序

PriorityQueue<Integer> maxHeap = new PriorityQueue<Integer>(k, new Comparator<Integer>() { 
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2.compareTo(o1);
            }
        });

或者

//自定义比较器,降序排列
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);//此处使用cmp比较器说明
        qq.add(3);
        qq.add(2);
        qq.add(4);
        while(!qq.isEmpty())
        {
            System.out.print(qq.poll()+" ");
        }
        /**
         * 输出结果
         * 4 3 2 
         */
}

小表显示jdk1.5中的阻塞队列的操作:

函数 操作 异常
add 增加一个元素 如果队列已满,则抛出一个lllegalSlabEepeplian异常
remove 移除并返回队列头部的元素 如果队列为空,则抛出一个NoSuchElementException异常
element 返回队列头部的元素 如果队列为空,则抛出一个NosuchElementException异常
offer 添加一个元素并返回true 如果队列已满,则返回false
poll 移除并返回队列头部的元素 如果队列为空,则返回null
peek 返回队列头部的元素 如果队列为空,则返回null
put 添加一个元素 如果队列满,则阻塞
take 移除并返回队列头部的元素 **

相关文章

  • C++ STL priority_queue 使用说明

    说明 优先队列std::priority_queue 可用于构造堆。 比如:大顶堆:priority_queue ...

  • priority_queue 优先级队列的使用

    priority_queue 优先级队列是一个拥有权值概念的单向队列 queue,在这个队列中,所有元素是按优先级...

  • STL容器(3)-priority_queue类

    STL容器(3)-priority_queue类 优先级队列 优先级队列本质就是一个堆,在C语言中可以使用数组来实...

  • Queue的使用、priority_queue优先队列

    1、Queue的使用(FIFO)(使用LinkedList实现) Queue使用时要尽量避免Collection的...

  • priority_queue

    priority_queue 优先队列,其底层是用堆来实现的。在优先队列中,队首元素一定是当前队列中优先级最高的那...

  • priority_queue

    priority_queue又称为优先队列,其底层是用堆来进行实现的。在优先队列中,队首元素一定是当前队列中优先级...

  • Objective-C封装std::priority_queue

    原文地址:Objective-C封装std::priority_queue<>实现优先队列最近项目中需要用到优先队...

  • 优先队列与结构体

    priority_queue q:默认将队列中的数从大到小排序;priority_queue ,greate...

  • CodeForces - 681C 【优先队列】

    传送门优先队列在语法(推入,删除)上与普通队列一样,不同在于声明时要这样:priority_queue ,grea...

  • STLRecipe---priority_queue

    priority_queue容器适配器定义了一个元素有序排列的队列,默认队列头部的元素优先级最高。 priorit...

网友评论

      本文标题:Queue的使用、priority_queue优先队列

      本文链接:https://www.haomeiwen.com/subject/kirccctx.html