栈
介绍
1、栈是一个先入后出(FILO-First In Last Out)的有序列表。
2、栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表。允许插入和删除的一端,为变化的一端,称为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)。
3、根据栈的定义可知,最先放入栈中元素在栈底,最后放入的元素在栈顶,而删除元素刚好相反,最后放入的元素最先删除,最先放入的元素最后删除
栈的应用场景
1、子程序的调用:在跳往子程序前,会先将下个指令的地址存到堆栈中,直到子程序执行完后再将地址取出,以回到原来的程序中。
2、处理递归调用:和子程序的调用类似,只是除了储存下一个指令的地址外,也将参数、区域变量等数据存入堆栈中。
3、表达式的转换[中缀表达式转后缀表达式]与求值(实际解决)。
4、二叉树的遍历。
5、图形的深度优先(depth一first)搜索法。
数组模拟栈
package top.pro51.stack;
import java.util.Scanner;
/**
* @ClassName ArrayStackDemo
* @Description: 数组模拟栈
* @Author: WangWenpeng
* @date: 14:57 2020/9/13
* @Version 1.0
*/
public class ArrayStackDemo {
public static void main(String[] args) {
ArrayStack stack = new ArrayStack(5);
boolean loop = true;
String key = "";
Scanner scanner = new Scanner(System.in);
while (loop) {
System.out.println("s-show: 表示显示栈");
System.out.println("e-exit: 退出程序");
System.out.println("p-push: 表示添加数据到栈(入栈)");
System.out.println("g-pop: 表示从栈取出数据(出栈)");
System.out.println("请输入你的选择");
key = scanner.next();
switch (key) {
case "s":
stack.list();
break;
case "p":
System.out.println("请输入一个数");
int value = scanner.nextInt();
stack.push(value);
break;
case "g":
try {
int res = stack.pop();
System.out.printf("出栈的数据是 %d\n", res);
} catch (Exception e) {
System.out.println(e.getMessage());
}
break;
case "e":
scanner.close();
loop = false;
break;
default:
break;
}
}
System.out.println("程序退出~~~");
}
}
/**
* @Description 数组模拟栈
* @Author WangWenpeng
* @Date 15:22 2020/9/13
* @Param
*/
class ArrayStack {
private int maxSize;
private int[] stack;
//top 标识栈顶 初始化为-1
private int top = -1;
public ArrayStack(int maxSize) {
this.maxSize = maxSize;
stack = new int[this.maxSize];
}
/**
* 栈是否已经满了
*
* @return
*/
public boolean isFull() {
return top == maxSize - 1;
}
/**
* 栈空判断
*
* @return
*/
public boolean isEmpty() {
return top == -1;
}
/**
* 栈添加 压栈
*
* @param value
*/
public void push(int value) {
if (isFull()) {
System.out.println("栈满,不能添加");
return;
}
//top++;
//stack[top] = value;
stack[++top] = value;
}
/**
* 出栈
*
* @return
*/
public int pop() {
if (isEmpty()) {
System.out.println("栈空,不能出栈");
throw new RuntimeException("栈空,不能出栈");
}
return stack[top--];
}
/**
* 遍历
*/
public void list() {
if (isEmpty()) {
System.out.println("栈空,没有数据");
return;
}
for (int i = top; i >= 0; i--) {
System.out.printf("stack[%d]=%d\n", i, stack[i]);
}
}
}
流程图
代码示例
码云地址https://gitee.com/magneto/codeReview/tree/master/SGGDataStructure/DataStructure
微信
个人网站
http://www.51pro.top
公众号