java实现单向循环队列
/**
* @author zx_jiao
* @create 05-23 22:20
*/
@SuppressWarnings("unchecked")
public class CircleQueue<E> {
private int front;
private E[] elements;
private int size;
private static final int DEFAULT_CAPACITY = 10;
public CircleQueue() {
elements = (E[]) new Object[DEFAULT_CAPACITY];
}
public int size() {
return size;
}
public boolean isEmpty() {
return size == 0;
}
public void enQueue(E element) {
ensureCapacity(size + 1);
elements[index(size)] = element;
size++;
}
/**
* 保证要有capacity的容量
*
* @param capacity
*/
private void ensureCapacity(int capacity) {
int oldCapacity = elements.length;
if (oldCapacity >= capacity) return;
// 新容量为旧容量的1.5倍
int newCapacity = oldCapacity + (oldCapacity >> 1);
E[] newElements = (E[]) new Object[newCapacity];
for (int i = 0; i < size; i++) {
newElements[i] = elements[index(i)];
}
elements = newElements;
front = 0;
System.out.println(oldCapacity + "扩容为" + newCapacity);
}
//封装索引
private int index(int index) {
return index - (index >= elements.length ? elements.length : 0);
}
public E deQueue() {
E frontElement = elements[front];
elements[front] = null;
front = index(1);
size--;
return frontElement;
}
public E front() {
return elements[front];
}
@Override
public String toString() {
return "CircleQueue{" +
"front=" + front +
", elements=" + Arrays.toString(elements) +
", size=" + size +
'}';
}
}