news 2025/12/27 13:58:04

一文吃透栈(Stack):从底层原理到经典算法实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一文吃透栈(Stack):从底层原理到经典算法实战

一、什么是栈?

栈(Stack):是一种后进先出(LIFO,Last In First Out)的数据结构。

栈的核心特性

  • 只能在一端操作(称为栈顶 top

  • 基本操作:

    • 入栈(push)

    • 出栈(pop)

    • 查看栈顶(peek)

二、栈的逻辑结构 vs 物理结构

逻辑结构:

栈顶 ┌───┐ │ 3 │ ├───┤ │ 2 │ ├───┤ │ 1 │ └───┘ 栈底

物理实现方式:

  1. 数组实现(顺序栈)

  2. 链表实现(链式栈)


三、手写一个顺序栈(数组实现)

1. 栈的基本结构

public class ArrayStack { private int[] data; // 存放元素 private int top; // 栈顶指针 private int capacity; public ArrayStack(int capacity) { this.capacity = capacity; data = new int[capacity]; top = -1; // 栈空 } }

2. 入栈(push)

public void push(int value) { if (top == capacity - 1) { throw new RuntimeException("栈满,无法入栈"); } data[++top] = value; }

关键点:

  • top == capacity - 1→ 栈满

  • ++top再赋值


3. 出栈(pop)

public int pop() { if (top == -1) { throw new RuntimeException("栈空,无法出栈"); } return data[top--]; }

关键点:

  • 先取值,再top--


4. 查看栈顶(peek)

public int peek() { if (top == -1) { throw new RuntimeException("栈空"); } return data[top]; }

5. 测试代码

public static void main(String[] args) { ArrayStack stack = new ArrayStack(5); stack.push(1); stack.push(2); stack.push(3); System.out.println(stack.pop()); // 3 System.out.println(stack.peek()); // 2 }

四、链式栈(链表实现)

优势:不需要扩容,不受数组大小限制

1. 节点定义

class Node { int value; Node next; Node(int value) { this.value = value; } }

2. 栈结构

public class LinkedStack { private Node top; public LinkedStack() { top = null; } }

3. 入栈(头插法)

public void push(int value) { Node node = new Node(value); node.next = top; top = node; }

4. 出栈

public int pop() { if (top == null) { throw new RuntimeException("栈空"); } int value = top.value; top = top.next; return value; }

五、栈的经典应用 ①:括号匹配

问题描述

输入: "{[()]}" 输出: true

解题思路

  • 左括号 → 入栈

  • 右括号 → 弹栈匹配


代码实现

public static boolean isValid(String s) { Deque<Character> stack = new ArrayDeque<>(); for (char c : s.toCharArray()) { if (c == '(' || c == '[' || c == '{') { stack.push(c); } else { if (stack.isEmpty()) return false; char top = stack.pop(); if (c == ')' && top != '(') return false; if (c == ']' && top != '[') return false; if (c == '}' && top != '{') return false; } } return stack.isEmpty(); }

六、栈的经典应用 ②:表达式求值(逆波兰)

示例

输入:["2","1","+","3","*"] 输出:9

代码实现

public static int evalRPN(String[] tokens) { Deque<Integer> stack = new ArrayDeque<>(); for (String token : tokens) { if ("+-*/".contains(token)) { int b = stack.pop(); int a = stack.pop(); switch (token) { case "+": stack.push(a + b); break; case "-": stack.push(a - b); break; case "*": stack.push(a * b); break; case "/": stack.push(a / b); break; } } else { stack.push(Integer.parseInt(token)); } } return stack.pop(); }

七、栈在系统层面的真实应用

1. JVM 虚拟机栈

  • 每个线程一个栈

  • 栈帧包含:

    • 局部变量表

    • 操作数栈

    • 返回地址

递归本质 = 不断入栈


2. 函数调用过程

void a() { b(); } void b() { c(); }

调用顺序:

a 入栈 b 入栈 c 入栈 c 出栈 b 出栈 a 出栈

八、栈常见面试问题总结

题型关键词
括号匹配
单调栈下一个更大元素
表达式求值操作数栈
DFS / 回溯系统栈
中序 → 后序

九、总结一句话

栈的本质:延迟处理 + 最近优先

掌握栈,你会突然发现:

  • 递归不再神秘

  • 表达式计算有迹可循

  • 很多“看起来复杂”的问题,本质只是一个栈

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/17 15:33:18

“负碳航空”的流行,是工业文明的一场“赎罪”与“自救”。

在人类工业文明的宏大叙事中&#xff0c;航空业宛如一颗璀璨却又带着阴影的星辰。它以惊人的速度缩短了世界的距离&#xff0c;让人类实现了“天涯若比邻”的梦想&#xff0c;但同时也成为了碳排放的“大户”。据英国约克大学预测&#xff0c;到2050年&#xff0c;航空飞行造成…

作者头像 李华
网站建设 2025/12/17 15:33:05

企业数据中台建设终极指南:3步搞定数据治理难题

&#x1f4cc; 数据中台建设的现实困境 【免费下载链接】LarkMidTable LarkMidTable 是一站式开源的数据中台&#xff0c;实现中台的 基础建设&#xff0c;数据治理&#xff0c;数据开发&#xff0c;监控告警&#xff0c;数据服务&#xff0c;数据的可视化&#xff0c;实现高效…

作者头像 李华
网站建设 2025/12/27 8:28:47

告别繁琐!这款Mac免费Gif工具让你3步搞定屏幕录制

告别繁琐&#xff01;这款Mac免费Gif工具让你3步搞定屏幕录制 【免费下载链接】GifCapture &#x1f3c7; Gif capture app for macOS 项目地址: https://gitcode.com/gh_mirrors/gi/GifCapture 还在为制作Gif动画而头疼吗&#xff1f;&#x1f629; 每次想要录制屏幕操…

作者头像 李华
网站建设 2025/12/23 2:00:01

宏智树AIPPT,用AI把学术表达变成一场轻松对话

你有没有经历过这样的深夜&#xff1f; 键盘敲得发烫、咖啡凉了三杯、眼睛干涩发红&#xff0c;却还在第7页PPT的排版里打转——字体不对、逻辑混乱、图表丑得自己都看不下去。更崩溃的是&#xff0c;明天就要在组会上汇报&#xff0c;导师还特意强调&#xff1a;“PPT要专业、…

作者头像 李华
网站建设 2025/12/22 22:37:16

如何快速构建Python GUI界面?这款可视化设计工具让你告别手写代码

如何快速构建Python GUI界面&#xff1f;这款可视化设计工具让你告别手写代码 【免费下载链接】tkinter-helper 为tkinter打造的可视化拖拽布局界面设计小工具 项目地址: https://gitcode.com/gh_mirrors/tk/tkinter-helper 作为一名Python开发者&#xff0c;你是否曾经…

作者头像 李华