当前位置: 首页 > news >正文

【数据结构】栈与链表的区别

- 第 111篇 -
Date: 2025 - 07 - 16
Author: 郑龙浩(仟墨)

栈与链表的区别

一、基本概念

1. 栈是什么?

栈就像一摞盘子,只能从最上面拿取或放入新盘子, 专业术语叫"后进先出"(LIFO)结构

LIFO:last in first out

  • 只能在一端操作(栈顶)
  • 基本操作就两个:push(压栈)和pop(弹栈)
  • 可以用数组或链表实现

2. 链表是什么?

它由多个节点组成,每个节点存储数据和下一个节点的地址。

  • 可以随意在任何位置插入和删除
  • 不需要连续的内存空间
  • 常见类型:单向链表、双向链表、循环链表

3. 相同之处

其实链表和栈结构是非常相似的,最大的区别就是栈有了限制,只能在一端进行操作,而链表可以在两端甚至中间任意位置进行操作。

二、核心区别

1. 操作方式不同

操作链表
插入只能在栈顶push可以在任意位置插入
删除只能从栈顶pop可以删除任意节点
访问只能看栈顶元素可以遍历所有节点

2. 内存使用不同

  • 顺序栈(数组实现的栈):大小固定,可能浪费空间
  • 链栈(链表实现的栈):动态分配
  • 普通链表:最灵活

三、应用场景

1. 栈的典型用途

  • 浏览器后退按钮:最后访问的网址最先显示
  • 撤销操作:最后做的操作最先撤销
  • 函数调用:最后调用的函数最先返回

2. 链表的典型用途

  • 实现其他数据结构(如队列、图)
  • 需要频繁插入删除的场景
  • 内存管理系统中的内存分配
http://www.lryc.cn/news/590356.html

相关文章:

  • 构建足球实时比分APP:REST API与WebSocket接入方案详解
  • 【25】MFC入门到精通——MFC静态文本框 中字符串 连续输出 不覆盖先前的文本 换行输出
  • 基于深度学习的情感分析模型:从文本数据到模型部署
  • 推客系统开发:从零构建高并发社交平台的技术实践
  • 【前端】Vue3 前端项目实现动态显示当前系统时间
  • 每天一个前端小知识 Day 33 - 虚拟列表与长列表性能优化实践(Virtual Scroll)
  • Python 与JA3 库的应用
  • 接口幂等性设计:用Redis避免接口重复请求
  • 前端技术之---应用国际化(vue-i18n)
  • 中医文化学习软件,传承国粹精华
  • Java全栈面试实录:从电商支付到AIGC的深度技术考察
  • 什么是数据仓库?数据库与数据仓库有什么关系?
  • 基于WebRTC构建应用的可复用模块
  • Ansible 查看PostgreSQL的版本
  • Rocky9安装Ansible
  • Android CameraX使用
  • PyCharm高效入门指南
  • 深度解析:如何在 Windows 系统中高效配置 Android MCP 服务
  • 【Unity】IL2CPP相关理论知识学习
  • CSS:transition语法
  • 网络安全初级(XSS-labs 1-8)
  • 【黑客与安全】windows平台的BurpSuite的安装
  • Opencv---cv::minMaxLoc函数
  • API Gateway HTTP API 控制客户端访问 IP 源
  • [硬件电路-28]:从简单到复杂:宇宙、芯片与虚拟世界的共通逻辑
  • Linux 716 数据库迁移
  • 汽车电子功能安全标准ISO26262解析(二)——需求部分
  • 网络编程(数据库)
  • ST表及数学归纳法
  • LLM OCR vs 传统 OCR:解锁文档处理的未来