• 【C++】STL——stack&queue的基本使用


    目录

    stack

    一、stack简介

    二、stack的定义方式 

    三、stack完整结构图 

    四、stack常用接口的使用

    queue

    一、queue的简介

    二、queue定义方式

    三、queue完整结构图

    四、queue常用接口的使用


    stack

    一、stack简介

            stack是一种先进后出的数据结构。它只有一个出口,如下图所示。stack允许新增元素、移除元素、取得栈顶元素。但除了最顶端外,没有任何方法可以存取stack的其它元素。换言之,stack不允许有遍历行为(即stack没有迭代器)。

    二、stack的定义方式 

            stack是以某种容器作为底部结构,将其接口改变,使之符合“先进后出”的特性,形成一个stack。默认的底部结构是deque(双端队列),deque是双向开口的数据结构。

            由于stack是以底部容器完成其所有工作的,而具有这种"修改某物接口,形成另一种风貌"之性质者,称之为(adapter)配接器(好比苹果手机的耳机在没有配接器的情况下,是不可以使用圆柱插孔式的耳机的,有了配接器能够很好的适应);往往stack不被归类为容器,而是容器配接器(容器适配器)。(注:deque示意图在文末)

    1. stack<int> st1; //默认不写第二个参数,底部容器是基于deque
    2. stack<int,vector<int>> st2; //底部容器是基于vector

    三、stack完整结构图 

            下图即为stack的完整结构图,底部基于所选择的容器来进行数据的操作,只要选用的容器的功能能够满足stack的使用需求即可;

     

    四、stack常用接口的使用

    stack的核心接口由三个成员函数提供:push( )、top( )、pop( )。

    push( ) --- 将一个元素压入stack内;

    top( ) --- 返回栈顶元素的引用

    pop( ) --- 从stack中移除栈顶元素

    注意:如果你想移除stack的下一个元素同时返回它,就必须调用top( )和pop( )

    常用函数说明
    stack()构造空的栈
    empty()检查stack是否为空
    size()返回stack中元素的个数
    top()返回栈顶元素的引用
    push()将元素val压入stack中
    pop()将stack中尾部的元素弹出
    1. void test_stack()
    2. {
    3. stack<int> st;//实例化出一个栈,会调用它的构造函数 --- stack()
    4. st.push(1);
    5. st.push(2);
    6. st.push(3);
    7. st.push(4);//将1 2 3 4 压入栈中
    8. st.size();//返回栈中的元素个数
    9. while (!st.empty())//判断栈是否为空
    10. {
    11. cout << st.top() << " ";//取栈顶的元素
    12. st.pop();//删除栈顶的元素
    13. }
    14. cout << endl;
    15. }

    queue

    一、queue的简介

            queue是一种先进先出的数据结构,它允许新增元素、移除元素、从队尾插入元素、取队头的元素。但除了队尾可以插入元素、队头取出元素之外,没有任何办法存取其他元素。queue也不允许有遍历行为(即queue没有迭代器)。

    二、queue定义方式

            queue是以某种容器作为底部结构,将其接口改变,使之符合“先进先出”的特性,形成一个queue。默认的底部结构是deque(双端队列),deque是双向开口的数据结构。

            由于queue是以底部容器完成其所有工作的,而具有这种"修改某物接口,形成另一种风貌"之性质者,称之为(adapter)配接器。往往queue不被归类为容器,而是容器配接器(容器适配器)。(注:deque示意图在文末)

    1. queue<int> q1; //默认以deque为底部容器
    2. queue<int,list<int>> q2; //以list为底部容器

    三、queue完整结构图

            下图即为queue的完整结构图,底部基于所选择的容器来进行数据的操作,只要选用的容器的功能能够满足queue的使用需求即可;

    四、queue常用接口的使用

    queue的核心接口由四个成员函数提供:push( )、front( )、back( )、pop( )。

    push( ) --- 将一个元素压入queue内;

    front( ) --- 返回队头的元素

    back( ) --- 返回队尾的元素

    pop( ) --- 从queue中移除队头元素

    注意:如果你想获取队头的数据又想处理掉它,就必须调用front( ) 和pop( )

    常用函数说明
    queue()构造空的队列
    empty()检查队列是否为空
    size()返回队列中有效元素的个数
    front()返回队头元素的引用
    back()返回队尾元素的引用
    push()在队尾将元素val入队列
    pop()将队头元素出队列
    1. void test_queue()
    2. {
    3. queue<int> q;
    4. q.push(1);
    5. q.push(2);
    6. q.push(3);
    7. q.push(4);//尾插1 2 3 4
    8. q.size();//返回队列中有效元素的个数
    9. int qfront = q.front(); //取队头的数据
    10. int qback = q.back(); //取队尾的数据
    11. cout << qfront << " " << qback << endl;
    12. while (!q.empty())//判断队列是否为空
    13. {
    14. cout << q.front() << " ";
    15. q.pop();//删除队头的数据
    16. }
    17. cout << endl;
    18. }

            对于duque并未在这里做介绍,会在后续的stack和queue模拟实现中介绍,以下是deque的结构示意图:

     

  • 相关阅读:
    Vue:列表排序和筛选(运用计算属性和监视属性(侦听属性))
    筑牢安全生产防线,工厂人员定位报警系统护航企业发展
    Spring 中 Bean 对象的存储和取出
    R语言将数据转化为DALEX包期望的格式、使用DALEX包的explain函数对多个h2o算法模型构建解释器进行解释分析、使用验证集数据构建模型解释器
    【Dubbo3高级特性】「系统级别检查」服务端和消费端启动时检查
    华为年薪千万的大牛机器视觉搞了几十年,没有搞定的定位算法,现在我开源给大家。用于非标自动化行业。
    专注效率提升「GitHub 热点速览 v.22.36」
    上来就对标 20k Star 的开源项目,是自不量力还是后起之秀?
    层顶分布式光伏发电并网群调群控系统采集终端装置应用方案及分布式光伏调度数据远动通信屏柜配置方案
    Ubuntu上使用SSH连接到CentOS系统
  • 原文地址:https://blog.csdn.net/sjsjnsjnn/article/details/125475145