首页
学习
活动
专区
圈层
工具
发布

STL——stack容器和queue容器详解

---- stack 基本概念 栈(stack):一种特殊的线性表,其只允许在固定的一端进行插入和删除操作。在进行数据插入和删除的一端称为栈顶,另一端称为栈底。...生活中栈的例子: 常用接口 功能描述: 栈容器常用的对外接口 构造函数: stack stk; //stack采用模板类实现, stack对象的默认构造形式 stack(const...stack &stk); //拷贝构造函数 赋值操作: stack& operator=(const stack &stk); //重载等号操作符 数据存取: push...在另一端进行删除数据操作的特殊线性表,队列具有先进先出 FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队头 常用接口 功能描述: 栈容器常用的对外接口...构造函数: queue que; //queue采用模板类实现,queue对象的默认构造形式 queue(const queue &que); //拷贝构造函数

23910

STL之容器适配器(stack,queue和priority_queue)

容器适配器主要有三种: stack:是一个封装了 deque 容器的适配器类模板,默认实现的是一个后入先出的压入栈。...1.stack 图 展示了一个理论上的 stack 容器及其一些基本操作。只能访问 stack 顶部的元素;只有在移除 stack 顶部的元素后,才能访问下方的元素。...swap(stack & other_stack):将当前栈中的元素和参数中的元素交换。参数所包含元素的类型必须和当前栈的相同。...swap(queue &other_q):将当前 queue 中的元素和参数 queue 中的元素交换。 具体实例: 模拟超市运转的程序。结账队列的长度是超市运转的关键因素。...swap(priority_queue& other):和参数的元素进行交换,所包含对象的类型必须相同。

51530
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【STL】 stack 与 queue(C++)

    4.2 STL标准库中stack和queue的底层结构 虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装...,STL中stack和queue默认使用deque。...,deque的应用并不多,而目前能看到的一个应用就是,STL用其作为stack和queue的底层数据结构。...4.4 为什么选择deque作为stack和queue的底层默认容器 stack是一种后进先出的特殊线性数据结构,因此只要具有push_back()和pop_back()操作的线性结构,都可以作为stack...但是STL中对stack和queue默认选择deque作为其底层容器,主要是因为: 1. stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进 行操作。

    22410

    C++(STL3)容器适配器(1) stack,queue and priority_queue

    C++(STL3)容器适配器 容器适配器是一个封装了序列容器的类模板,它在一般序列容器的基础上提供了一些不同的功能。之所以称作适配器类,是因为它可以通过适配容器现有的接口来提供不同的功能。...目录 C++(STL3)容器适配器 一、stack 1.基本介绍 2.堆栈操作相关函数: 二、queue 1.基本认识 2.函数操作 三、priority_queue 1.基本介绍 2.priority_queue...2.堆栈操作相关函数: 和其他序列容器相比,stack 是一类存储机制简单、所提供操作较少的容器。下面是 stack 容器可以提供的一套完整操作: top():返回一个栈顶元素的引用,类型为 T&。... 1.基本认识 只能访问 queue 容器适配器的第一个和最后一个元素。...queue 模板定义了拷贝和移动版的 operator=(),对于所保存元素类型相同的 queue 对象,它们有一整套的比较运算符,这些运算符的工作方式和 stack 容器相同。

    86530

    【C++STL】stack和queue(容器适配器、优先队列、双端队列)

    目录 stack的介绍 stack常用接口 queue的介绍 queue的使用 容器适配器 什么是适配器 STL标准库中stack和queue的底层结构 deque的简单介绍 deque的缺陷...STL标准库中stack和queue的底层结构 虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装...,STL中stack和queue默认使用deque。...STL中对stack和queue默认选择deque作为其底层容器,主要是因为: stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作。...STL的六大组件 模拟实现 stack queue stack和queue的模拟实现基本一样。

    37210

    ​C++ STL源码剖析之容器配接器stack与queue、priority_queue

    C++ STL源码剖析之容器配接器stack与queue、priority_queue 0.导语 为何stack与queue不被称为容器呢? 下面本节带着这个问题来深入源码分析。...1.stack 在stack的源码中我们关注两点: 默认_Sequence为deque 内部函数实现是调用_Sequence对应容器的函数。 ?...底层容器 ” 对于stack来说,底层容器可以是vector、deque、list,但不可以是map、set。...测试这两个容器配接器支持的底层容器: ★queue ” 对于queue底层容器可以是deque,也可以是list,但不能是vector,map,set,使用默认的deque效率在插入方面比其他容器作为底层要快...因此,stack、queue、priority_queue不被称为容器, 把它称为容器配接器。

    1.1K40

    stack和queue

    4.2 STL标准库中stack和queue的底层结构 虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装...,STL中stack和queue默认使用deque,比如: 4.3 deque的简单介绍(了解) 4.3.1 deque的原理介绍 deque(双端队列):是一种双开口的"连续"空间的数据结构...,deque的应用并不多,而目前能看到的一个应用就是,STL用其作为stack和queue的底层数据结构。...()和pop_back()操作的线性结构,都可以作为stack的底层容器,比如vector和list都可以;queue是先进先出的特殊线性数据结构,只要具有push_back和pop_front操作的线性结构...但是STL中对stack和queue默认选择deque作为其底层容器,主要是因为: 1. stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作。

    17500

    【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)

    C++的两个参考文档 老朋友(非官方文档):cplusplus 官方文档(同步更新):cppreference stack容器文档链接:stack queue容器文档链接:queue 1...() 将stack中尾部的元素弹出 无参数 无返回值 O(1) 1.2 queue的使用 1.2.1 文档内容理解 1、队列是一种容器适配器,专门用于在FIFO上下文(先进先出)中操作,其中从容器一端插入元...pop_front:在队列头部出队列 4、标准容器类deque和list满足了这些要求。...默认情况下,如果没有为queue实例化指定容器 类,则使用标准容器deque。...和 queue的使用:构造、增删 #include #includestack> #includequeue> using namespace std; int main()

    19310

    C++STL容器stack

    3.5 stack容器 3.5.1 stack 基本概念 概念:stack是一种先进后出(First In Last Out,FILO)的数据结构,它只有一个出口 栈中只有顶端的元素才可以被外界使用,...因此栈不允许有遍历行为 栈中进入数据称为 — 入栈 push 栈中弹出数据称为 — 出栈 pop 生活中的栈: 子弹弹夹,拥挤的地铁 3.5.2 stack 常用接口 功能描述:栈容器常用的对外接口...构造函数: stack stk; //stack采用模板类实现, stack对象的默认构造形式 stack(const stack...&stk); //拷贝构造函数 赋值操作: stack& operator=(const stack &stk); //重载等号操作符 数据存取: push(...> //栈容器常用接口 void test01() { //创建栈容器 栈容器必须符合先进后出 stack s; //向栈中添加元素,叫做 压栈 入栈 s.push(10); s.push

    33540

    【c++】stack和queue使用 && stack和queue模拟实现

    STL标准库中stack和queue的底层结构 虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装...,STL中stack和queue默认使用deque,比如: 4.3 deque的简单介绍(了解) 4.3.1 deque的原理介绍 deque(双端队列):是一种双开口的"连续"空间的数据结构,双开口的含义是...,deque的应用并不多,而目前能看到的一个应用就是,STL用其作为stack和queue的底层数据结构 4.4 为什么选择deque作为stack和queue的底层默认容器 stack是一种后进先出的特殊线性数据结构...但是STL中对stack和queue默认选择deque作为其底层容器,主要是因为: stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作 在...4.5 STL标准库中对于stack和queue的模拟实现 4.5.1 stack的模拟实现 #pragma once #include #include #include

    23010

    【c++丨STL】stack和queue的使用及模拟实现

    前言 本篇文章,博主将介绍STL中两个比较重要的容器适配器:stack(栈)和queue(队列)以及它们的使用方法,并且尝试模拟实现它们。...、list这些容器不同,stack和queue被称作容器适配器。...STL在设计stack和queue时,并没有从零开始构建它们的底层结构,而是采用了这种设计思想,对现有容器进行了封装,从而实现了它们。...接下来,我们看看SGI版本的STL源码的stack实现: 可以看到,源码使用了一个叫做deque的容器创建对象,然后调用该对象的一些接口来实现stack的接口。..._con);//交换两个成员容器的内容 } private: Container _con;//成员容器 }; 总结 今天我们学习了STL两个适配器:stack和queue的使用及模拟实现

    37910

    【C++STL :stack && queue (二) 】stack 与 queue 的模拟实现与双端队列探秘

    5.2 STL标准库中stack和queue的底层结构 虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装...,STL中stack和queue默认使用deque,比如: 后面我们会介绍双端队列(deque)这个容器适配器。...,deque的应用并不多,而目前能看 到的一个应用就是,STL用其作为stack和queue的底层数据结构。...stack的底层容器,比如vector和list都可以;queue是先进先出的特殊线性数据结构,只要具有push_back和pop_front操作的线性结构,都可以作为queue的底层容器,比如list...但是STL中对stack和queue默认选择deque作为其底层容器,主要是因为: 1、stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作。

    15710
    领券