目录
前言
栈相当于一个箱子,往里面放书,要是取书,只能从上面拿。
一、什么是栈?
概念:栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。
简单理解:
1、栈是一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照先进后出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。
2、栈允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为先进后出表。
3、栈可以用来在函数调用的时候存储断点,做递归时要用到栈!
二、如何在代码中实现栈
下面我们主要在数组中实现栈的用法:
1、首先创建一个对象;
2、在对象中创建数组存储数据;
3、分别写好,压入也就是入栈方法,出栈方法,判断是否为空栈,查看栈顶元素方法。
package demo2;
public class MyStack {
//栈的底层使用数组存储数据
int[] elements;
public MyStack(){
elements = new int[0];
}
//压入元素
public void push(int elements){
//创建一个新的数组
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.lengh==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.lengh==0){
throw new RuntimeException("Stack is empty");
}
return elements[elements.length-1];
}
//判断栈是否为空
public boolean isEmpty(){
return elements.length==0;
}
}
对象完成后再新建一个测试类,首先在主函数中实例化对象,调用对象的方法。
packege demo2.test;
import demo2.MyStack;
public class TestMyStack{
public static void main(String[] args){
//创建一个栈
MyStack ms = new MyStack();
//压入数据
ms.push(9);
ms.push(8);
ms.push(7);
//取出栈顶元素
//System.out.println(ms.pop());//7
//System.out.println(ms.pop());//8
//System.out.println(ms.pop());//9
//查看栈顶元素
System.out.println(ms.peek());//7
System.out.println(ms.pop());//7
System.out.println(ms.peek());//8
//判断是否为空
System.out.println(ms.isEmpty());
}
}