自定义动态数组 见 数据结构-数组(Java)
自定义最大堆
/**
* @Author: FangJu
* @Date: 2019/8/19
*/
public class MaxHeap<E extends Comparable<E>> {
private Array<E> data;
public MaxHeap(int capacity) {
data = new Array<>(capacity);
}
public MaxHeap() {
data = new Array<>();
}
public MaxHeap(E[] arr) {
data = new Array<>(arr);
for (int i = parent(arr.length - 1); i >= 0; i--) {
siftDown(i);
}
}
public int size() {
return data.size();
}
public boolean isEmpty() {
return data.isEmpty();
}
private int parent(int index) {
if (index <= 0) {
throw new IllegalArgumentException("No Parent!");
}
return (index - 1) / 2;
}
private int leftChild(int index) {
return 2 * index + 1;
}
private int rightChild(int index) {
return 2 * index + 2;
}
public void add(E e) {
data.add(e);
siftUp(size() - 1);
}
//元素上浮
private void siftUp(int k) {
while (k > 0 && (data.get(k).compareTo(data.get(parent(k))) > 0)) {
data.swap(k, parent(k));
k = parent(k);
}
}
// 看堆中的最大元素
public E findMax() {
if (data.size() == 0)
throw new IllegalArgumentException("Can not findMax when heap is empty.");
return data.get(0);
}
// 取出堆中最大元素
public E extractMax() {
E ret = findMax();
data.swap(0, data.size() - 1);
data.removeLast();
siftDown(0);
return ret;
}
//元素下沉
private void siftDown(int k) {
while (leftChild(k) < data.size()) {
int j = leftChild(k); // 在此轮循环中,data[k]和data[j]交换位置
if (j + 1 < data.size() &&
data.get(j + 1).compareTo(data.get(j)) > 0)
j++;
// data[j] 是 leftChild 和 rightChild 中的最大值
if (data.get(k).compareTo(data.get(j)) >= 0)
break;
data.swap(k, j);
k = j;
}
}
// 取出堆中的最大元素,并且替换成元素e
public E replace(E e) {
E ret = findMax();
data.set(0, e);
siftDown(0);
return ret;
}
}
自定义优先队列(底层为最大堆,JDK为最小堆)
/**
* @Author: FangJu
* @Date: 2019/8/18
*/
public interface Queue<E> {
int getSize();
boolean isEmpty();
void push(E e);
E poll();
E peek();
}
/**
* @Author: FangJu
* @Date: 2019/8/19
*/
public class PriorityQueue<E extends Comparable<E>> implements Queue<E> {
private MaxHeap<E> maxHeap;
public PriorityQueue() {
maxHeap = new MaxHeap<>();
}
@Override
public int getSize() {
return maxHeap.size();
}
@Override
public boolean isEmpty() {
return maxHeap.isEmpty();
}
@Override
public void push(E e) {
maxHeap.add(e);
}
@Override
public E poll() {
return maxHeap.extractMax();
}
@Override
public E peek() {
return maxHeap.findMax();
}
}
相关例题 见 算法-前 K 个高频元素
其他数据结构 见 数据结构知识点汇总