第三章 栈,队列和数组

栈、队列与数组的对比与复习要点

栈(Stack)

栈是一种后进先出(LIFO)的线性结构,仅允许在栈顶进行插入(push)和删除(pop)操作。
核心操作

  • push(x):将元素x压入栈顶。
  • pop():弹出栈顶元素。
  • peek():获取栈顶元素但不删除。
  • isEmpty():判断栈是否为空。

应用场景

  • 函数调用栈(递归实现)。
  • 表达式求值(如括号匹配、中缀转后缀)。
  • 浏览器的前进后退功能。

实现方式

  • 数组实现:需预先分配固定大小,通过指针(如top)跟踪栈顶位置。
  • 链表实现:动态分配内存,灵活性更高。

考研常见考点

  • 栈的出入序列合法性(如给定入栈序列,判断某出栈序列是否可行)。
  • 双栈共享空间的设计(如两个栈共享一个数组)。

队列(Queue)

队列是一种先进先出(FIFO)的线性结构,插入在队尾(rear),删除在队头(front)。
核心操作

  • enqueue(x):将x插入队尾。
  • dequeue():删除队头元素。
  • front():获取队头元素。
  • isEmpty():判断队列是否为空。

特殊队列

  • 循环队列 :解决数组实现的假溢出问题,通过模运算实现环形结构。
    • 判空:front == rear
    • 判满:(rear + 1) % size == front
  • 双端队列(Deque):两端均可插入和删除。
  • 优先队列:元素按优先级出队,通常用堆实现。

应用场景

  • 任务调度(如CPU任务队列)。
  • 广度优先搜索(BFS)中的辅助数据结构。

考研常见考点

  • 循环队列的判空与判满条件。
  • 队列的链式实现(带头结点/不带头结点)。

数组(Array)

数组是连续内存存储的线性结构,支持随机访问(时间复杂度O(1))。
核心特性

  • 静态性:长度固定(动态数组如C++的vector可扩容,但需重新分配内存)。
  • 多维数组:如二维数组的行优先/列优先存储方式。

与栈/队列的区别

  • 栈和队列是逻辑结构,可用数组或链表实现;数组是物理存储结构。
  • 数组的插入/删除效率低(需移动元素),而栈/队列的插入删除严格受限。

考研常见考点

  • 数组的地址计算(如二维数组a[m][n]a[i][j]的地址)。
  • 稀疏矩阵的压缩存储(三元组表、十字链表)。

复习建议

  1. 对比记忆:总结三者的操作限制(如栈仅一端操作,队列两端操作但受限)。
  2. 代码实现:手写栈/队列的数组和链表实现,注意边界条件(如栈满/空)。
  3. 真题演练:重点练习出入序列合法性、循环队列判满等高频题型。
  4. 复杂度分析:明确栈/队列的插入删除均为O(1),数组插入删除为O(n)。

示例代码(C++)

cpp 复制代码
// 栈的数组实现
class Stack {
    int top, capacity;
    int* arr;
public:
    Stack(int size) : capacity(size), top(-1) { arr = new int[size]; }
    void push(int x) { if (top < capacity - 1) arr[++top] = x; }
    int pop() { if (!isEmpty()) return arr[top--]; return -1; }
    bool isEmpty() { return top == -1; }
};

// 循环队列实现
class CircularQueue {
    int front, rear, size;
    int* arr;
public:
    CircularQueue(int k) : size(k + 1), front(0), rear(0) { arr = new int[k + 1]; }
    bool enQueue(int x) {
        if (isFull()) return false;
        arr[rear] = x;
        rear = (rear + 1) % size;
        return true;
    }
    bool isFull() { return (rear + 1) % size == front; }
};
相关推荐
盛世宏博北京14 小时前
多协议温湿度传感器技术解析及系统集成方案设计
大数据·人工智能·温湿度传感器
谁似人间西林客14 小时前
工厂大脑:深度融合AI能力的智能化制造运营管理平台
大数据·人工智能·制造
Shadow(⊙o⊙)14 小时前
专题二滑动窗口
数据结构·算法
tankeven14 小时前
HJ181 相差不超过k的最多数
数据结构·c++·算法
XWalnut15 小时前
LeetCode刷题 day13
数据结构·算法·leetcode
杰克尼15 小时前
天机学堂项目总结(day1~day2)
大数据·jvm·spring·elasticsearch·搜索引擎·spring cloud·mybatis
小马_xiaoen15 小时前
前端虚拟列表(Virtual List)从原理到实战:海量数据渲染终极方案
前端·数据结构·list
炽烈小老头15 小时前
【每天学习一点算法 2026/04/17】多数元素
数据结构·学习·算法
简简单单就是我_hehe15 小时前
高吞吐、低成本日志系统方案ClickHouse + Filebeat/Fluentd
大数据
程序员雷欧16 小时前
Redis基础知识全解析:从数据结构到生产实战
数据结构·数据库·redis