数据结构--栈
程序员文章站
2024-01-19 16:55:10
...
- 栈也是线性结构
- 相比数组,栈对应的操作是数组的子集
- 只能从一端添加元素,也只能从一端取出元素
- 栈是限定仅在表尾进行插入和删除操作的线性表。 栈像向桶里装东西。
向栈添加元素称为入栈,向栈中取元素称为出栈。
栈是一种后进先出的数据结构。 允许插入和删除的一端叫做栈顶。栈元素是具有线性关系,即前驱后继关系。特殊的线性表。 应用:word 编辑器–撤销
Word 的撤销是用的是栈。 程序调用的系统栈 代码实现。
1.压入栈
2.出栈
3.查看栈顶
4.栈是否为空
public class MyStack {
//栈的底层我们使用数组来存储数据
int[] elements;
public MyStack() {
elements = new int[0];
}
//压入数据
public void push(int element) {
//创建一个新的数组,比原来数组长度加一。
int[] newArr = new int[elements.length + 1];
//把原来数组中的元素复制到新数组中
for (int i = 0; i < elements.length; i++) {
newArr[i] = elements[i];
}
//把添加的元素放入新数组中
newArr[elements.length] = element;
//使用新数组替换旧的数组
elements = newArr;
}
//取出栈顶元素
public int pop() {
//栈中没有元素
if (elements.length == 0) {
throw new RuntimeException("stack is empty");
}
//取出数组的最后一个元素
int element = elements[elements.length - 1];
//创建一个新的数组
int[] newArr = new int[elements.length - 1];
//原数组中除了最后一个元素的其他元素都放入新的数组中
for (int i = 0; i < elements.length - 1; i++) {
newArr[i] = elements[i];
}
//替换数组
elements = newArr;
//返回栈顶元素
return element;
}
//查看栈顶元素
public int peek() {
//栈中没有元素
if (elements.length == 0) {
throw new RuntimeException("stack is empty");
}
return elements[elements.length - 1];
}
//栈是否为空
public boolean isEmpty() {
return elements.length == 0;
}
}
下一篇: 数据结构——栈