Java 栈和队列
栈的概念(Stack)
栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,分为栈底和栈顶。栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等。 例如这把枪,第一发子弹是最后发射的,第一发子弹在栈底,而最新安装上去的子弹在栈的顶部,只有将上面的子弹打完(栈顶的数据走完),最后一发子弹才会射出。
栈的实现
栈的实现是基于简单的数组形成的,我们可以将它想象成连续的数组,而栈的顺序是由后放到前放。
模拟实现栈的方法:push(放入一个元素到栈中)、pop(提取栈顶的一个元素,并将在其栈中消除)、peek(查看栈顶的元素)、size(查看栈中的大小)、empty(栈中是否为空)、full(栈是否满了)。
import java.util.Arrays;
public class MyStack implements IStack {
private int[] elem;
private int top; // 数组的栈顶,以及数组栈中存放元素的数量
private static final int DEFAULT_CAPACITY = 10; // 这里是初始容量
public MyStack() {
elem = new int[DEFAULT_CAPACITY];
top = -1; // 数组下标从 0 开始
}
@Override
public void push(int item) {
if (full()) { // 如果满了就扩容
elem = Arrays.copyOf(elem, 2 * elem.length);
}
elem[++top] = item;
}
@Override
public int pop() throws RuntimeException {
{
(empty()) {
();
}
} (RuntimeException e) {
e.printStackTrace();
}
elem[top--];
}
{
(empty()) {
();
}
elem[top];
}
{
top + ;
}
{
top == -;
}
{
top == elem.length;
}
}


