⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 heaporderedlistpriorityqueue.java

📁 BOOK:Beginning Algorithms Code Examples
💻 JAVA
字号:
package com.wrox.algorithms.queues;import com.wrox.algorithms.lists.ArrayList;import com.wrox.algorithms.lists.List;import com.wrox.algorithms.sorting.Comparator;/** * A Priority {@link Queue} that uses a heap-ordered {@link List} internally. * */public class HeapOrderedListPriorityQueue implements Queue {    /** The underlying list. */    private final List _list;    /** The comparator to determine priority. */    private final Comparator _comparator;    /**     * Constructor. Uses a {@link ArrayList} as the underlying list.     *     * @param comparator The comparator to determine priority.     */    public HeapOrderedListPriorityQueue(Comparator comparator) {        assert comparator != null : "comparator cannot be null";        _comparator = comparator;        _list = new ArrayList();    }    public void enqueue(Object value) {        _list.add(value);        swim(_list.size() - 1);    }    private void swim(int index) {        if (index == 0) {            return;        }        int parent = (index - 1) / 2;        if (_comparator.compare(_list.get(index), _list.get(parent)) > 0) {            swap(index, parent);            swim(parent);        }    }    private void swap(int index1, int index2) {        Object temp = _list.get(index1);        _list.set(index1, _list.get(index2));        _list.set(index2, temp);    }    public Object dequeue() throws EmptyQueueException {        if (isEmpty()) {            throw new EmptyQueueException();        }        Object result = _list.get(0);        if (_list.size() > 1) {            _list.set(0, _list.get(_list.size() - 1));            sink(0);        }        _list.delete(_list.size() - 1);        return result;    }    private void sink(int index) {        int left = index * 2 + 1;        int right = index * 2 + 2;        if (left >= _list.size()) {            return;        }        int largestChild = left;        if (right < _list.size()) {            if (_comparator.compare(_list.get(left), _list.get(right)) < 0) {                largestChild = right;            }        }        if (_comparator.compare(_list.get(index), _list.get(largestChild)) < 0) {            swap(index, largestChild);            sink(largestChild);        }    }    public void clear() {        _list.clear();    }    public int size() {        return _list.size();    }    public boolean isEmpty() {        return _list.isEmpty();    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -