C++ stack 和 queue

什么是 stack(栈)?

想象一下你有一把ak,你给ak上膛子弹,最后上膛的子弹先发射出去。这种"后进先出"的结构就是

常用操作:
  • push(x):把元素 x 压入栈顶。

  • pop():移除栈顶元素(但不返回值)。

  • top():查看栈顶元素的值。

  • empty():判断栈是否为空。

  • size():返回栈中元素个数。

    cs 复制代码
    #include <iostream>
    #include <stack>
    using namespace std;
    
    int main() {
        stack<int> s;
    
        s.push(10);
        s.push(20);
        s.push(30);
    
        cout << s.top() << endl; // 输出: 30
        s.pop();
        cout << s.top() << endl; // 输出: 20
    
        return 0;
    }
    什么是 queue(队列)?

    想象你在排队买奶茶,新来的人要排在队尾 ,而服务员从队首 开始服务。这种"先进先出"的结构就是队列

    常用操作:
  • push(x):把元素 x 加入队尾。

  • pop():移除队首元素。

  • front():查看队首元素。

  • back():查看队尾元素。

  • empty()size():和 stack 一样。

    cpp 复制代码
    #include <iostream>
    #include <queue>
    using namespace std;
    
    int main() {
        queue<string> q;
    
        q.push("Alice");
        q.push("Bob");
        q.push("Charlie");
    
        cout << q.front() << endl; // 输出: Alice
        q.pop();
        cout << q.front() << endl; // 输出: Bob
    
        return 0;
    }
    总结对比
    操作 stack(栈) queue(队列)
    添加元素 push(x) push(x)
    删除元素 pop()(栈顶) pop()(队首)
    查看元素 top() front() / back()
    顺序 后进先出 先进先出
使用场景
  • stack:括号匹配、函数调用栈、撤销操作
  • queue:任务调度、BFS(广度优先搜索)、打印任务队列
  • 记住头文件:#include <stack>#include <queue>
  • pop() 只删除,不返回值,要用 top()front() 先看值。
  • 别忘了检查 empty(),否则访问空容器会出错!
相关推荐
多米Domi01110 分钟前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试
2301_8223776511 分钟前
模板元编程调试方法
开发语言·c++·算法
csbysj202014 分钟前
Python 循环嵌套
开发语言
测试_AI_一辰16 分钟前
Agent & RAG 测试工程05:把 RAG 的检索过程跑清楚:chunk 是什么、怎么来的、怎么被命中的
开发语言·人工智能·功能测试·自动化·ai编程
Coding茶水间19 分钟前
基于深度学习的输电电力设备检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
开发语言·人工智能·深度学习·yolo·目标检测·机器学习
清风~徐~来23 分钟前
【视频点播系统】BRpc 介绍及使用
开发语言
啟明起鸣24 分钟前
【C++ 性能提升技巧】C++ 的引用、值类型、构造函数、移动语义与 noexcept 特性,可扩容的容器
开发语言·c++
故以往之不谏26 分钟前
函数--值传递
开发语言·数据结构·c++·算法·学习方法
卢锡荣40 分钟前
Type-c OTG数据与充电如何进行交互使用应用讲解
c语言·开发语言·计算机外设·电脑·音视频