本文共 1129 字,大约阅读时间需要 3 分钟。
栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针。栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表。
堆栈只定义了默认构造函数,用来创建一个空栈。 堆栈除了包括由Vector定义的所有方法,也定义了自己的一些方法。
Stack()除了由Vector定义的所有方法,自己也定义了一些方法:
boolean empty() //测试堆栈是否为空。Object peek( )//查看堆栈顶部的对象,但不从堆栈中移除它。Object pop( )//移除堆栈顶部的对象,并作为此函数的值返回该对象。Object push(Object element)//把项压入堆栈顶部。int search(Object element)//返回对象在堆栈中的位置,以 1 为基数。
如何自己实现一个栈呢?
其实用数据就能实现:
public class stack { private int maxSize;//指定栈的大小 private int top;//栈顶 private char[] arr;//存储数组及类型 public stack(int size) {//实现方法 maxSize = size; top = -1; arr = new char[maxSize]; } public void push(char value) { // 压入数据 arr[++top] = value; } public char pop() { // 弹出数据 return arr[top--]; } public char peek() { // 访问栈顶元素 return arr[top]; } public boolean isFull() { // 栈是否满了 return maxSize - 1 == top; } public boolean isEmpty() { // 栈是否为空 return top == -1; }
转载地址:http://qtssn.baihongyu.com/