zoukankan      html  css  js  c++  java
  • PriorityQueue优先级队列

    PriorityQueue是什么?

    一个基于优先级堆的无界优先级队列。优先级队列的元素按照其自然顺序进行排序,或者根据构造队列时提供的 Comparator 进行排序,具体取决于所使用的构造方法。优先级队列不允许使用 null 元素。依靠自然顺序的优先级队列还不允许插入不可比较的对象(这样做可能导致 ClassCastException

    方法:

    1).add:插入一个元素,成功:true,失败:ClassCastException - 优先级队列的顺序无法将指定元素与此优先级队列中当前元素进行比较;NullPointerException - 指定元素为 null

        public boolean add(E e) {
            return offer(e);
        }

    2).offer:插入一个元素,成功:true,失败:ClassCastException - 优先级队列的顺序无法将指定元素与此优先级队列中当前元素进行比较;NullPointerException - 指定元素为 null

        public boolean offer(E e) {
            if (e == null)
                throw new NullPointerException();
            modCount++;
            int i = size;
            if (i >= queue.length)
                grow(i + 1);
            size = i + 1;
            if (i == 0)
                queue[0] = e;
            else
                siftUp(i, e);
            return true;
        }

    3).remove:删除一个元素,如果不成功会返回false。

        public boolean remove(Object o) {
            int i = indexOf(o);
            if (i == -1)
                return false;
            else {
                removeAt(i);
                return true;
            }
        }

    4).poll:删除队列头元素,并返回删除的元素

        public E poll() {
            if (size == 0)
                return null;
            int s = --size;
            modCount++;
            E result = (E) queue[0];
            E x = (E) queue[s];
            queue[s] = null;
            if (s != 0)
                siftDown(0, x);
            return result;
        }

    5).peek:获取但不移除此队列的头;如果此队列为空,则返回 null

        public E peek() {
            if (size == 0)
                return null;
            return (E) queue[0];
        }
    
        private int indexOf(Object o) {
            if (o != null) {
                for (int i = 0; i < size; i++)
                    if (o.equals(queue[i]))
                        return i;
            }
            return -1;
        }

    6).indexOf(Object o):查找对象o的索引;

        private int indexOf(Object o) {
            if (o != null) {
                for (int i = 0; i < size; i++)
                    if (o.equals(queue[i]))
                        return i;
            }
            return -1;
        }

    7).contain(Object o):判断是否容纳了元素

        public boolean contains(Object o) {
            return indexOf(o) != -1;
        }

    户枢不蠹,流水不腐

  • 相关阅读:
    软工小白菜的团队介绍和采访
    团队作业第二次——团队Github实战训练
    团队作业第一次—团队展示和项目展示
    week5:Technology: Internets and Packets
    week3:History: The Web Makes it Easy to Use
    week2:History: The First Internet
    week4:History: Commercialization and Growth
    week1:History: Dawn of Electronic Computing
    第二日会议博客
    第一日会议博客
  • 原文地址:https://www.cnblogs.com/yunianzeng/p/13229129.html
Copyright © 2011-2022 走看看