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

简介: 【C++】STL——stack&queue的基本使用

stack

一、stack简介

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

1ecd1b2606ed46e9956a89f231c9802c.png

二、stack的定义方式

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


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

1ecd1b2606ed46e9956a89f231c9802c.png

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

三、stack完整结构图

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

1ecd1b2606ed46e9956a89f231c9802c.png

四、stack常用接口的使用

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


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


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


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


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

1ecd1b2606ed46e9956a89f231c9802c.png

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

queue

一、queue的简介

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

1ecd1b2606ed46e9956a89f231c9802c.png

二、queue定义方式

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


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

1ecd1b2606ed46e9956a89f231c9802c.png

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

三、queue完整结构图

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

1ecd1b2606ed46e9956a89f231c9802c.png

四、queue常用接口的使用

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


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


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


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


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


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

1ecd1b2606ed46e9956a89f231c9802c.png

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

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

1ecd1b2606ed46e9956a89f231c9802c.png

目录
相关文章
|
23天前
|
存储 缓存 C++
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
C++ 标准模板库(STL)提供了一组功能强大的容器类,用于存储和操作数据集合。不同的容器具有独特的特性和应用场景,因此选择合适的容器对于程序的性能和代码的可读性至关重要。对于刚接触 C++ 的开发者来说,了解这些容器的基础知识以及它们的特点是迈向高效编程的重要一步。本文将详细介绍 C++ 常用的容器,包括序列容器(`std::vector`、`std::array`、`std::list`、`std::deque`)、关联容器(`std::set`、`std::map`)和无序容器(`std::unordered_set`、`std::unordered_map`),全面解析它们的特点、用法
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
|
15天前
|
存储 算法 C++
【c++丨STL】priority_queue(优先级队列)的使用与模拟实现
本文介绍了STL中的容器适配器`priority_queue`(优先级队列)。`priority_queue`根据严格的弱排序标准设计,确保其第一个元素始终是最大元素。它底层使用堆结构实现,支持大堆和小堆,默认为大堆。常用操作包括构造函数、`empty`、`size`、`top`、`push`、`pop`和`swap`等。我们还模拟实现了`priority_queue`,通过仿函数控制堆的类型,并调用封装容器的接口实现功能。最后,感谢大家的支持与关注。
52 1
|
26天前
|
设计模式 C++ 容器
c++中的Stack与Queue
c++中的Stack与Queue
|
2月前
|
C++ 容器
【c++丨STL】stack和queue的使用及模拟实现
本文介绍了STL中的两个重要容器适配器:栈(stack)和队列(queue)。容器适配器是在已有容器基础上添加新特性或功能的结构,如栈基于顺序表或链表限制操作实现。文章详细讲解了stack和queue的主要成员函数(empty、size、top/front/back、push/pop、swap),并提供了使用示例和模拟实现代码。通过这些内容,读者可以更好地理解这两种数据结构的工作原理及其实现方法。最后,作者鼓励读者点赞支持。 总结:本文深入浅出地讲解了STL中stack和queue的使用方法及其模拟实现,帮助读者掌握这两种容器适配器的特性和应用场景。
66 21
|
23天前
|
存储 算法 C++
深入浅出 C++ STL:解锁高效编程的秘密武器
C++ 标准模板库(STL)是现代 C++ 的核心部分之一,为开发者提供了丰富的预定义数据结构和算法,极大地提升了编程效率和代码的可读性。理解和掌握 STL 对于 C++ 开发者来说至关重要。以下是对 STL 的详细介绍,涵盖其基础知识、发展历史、核心组件、重要性和学习方法。
|
23天前
|
编译器 C++ 开发者
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。
|
2天前
|
设计模式 安全 C++
【C++进阶】特殊类设计 && 单例模式
通过对特殊类设计和单例模式的深入探讨,我们可以更好地设计和实现复杂的C++程序。特殊类设计提高了代码的安全性和可维护性,而单例模式则确保类的唯一实例性和全局访问性。理解并掌握这些高级设计技巧,对于提升C++编程水平至关重要。
31 16
|
6天前
|
安全 C++
【c++】继承(继承的定义格式、赋值兼容转换、多继承、派生类默认成员函数规则、继承与友元、继承与静态成员)
本文深入探讨了C++中的继承机制,作为面向对象编程(OOP)的核心特性之一。继承通过允许派生类扩展基类的属性和方法,极大促进了代码复用,增强了代码的可维护性和可扩展性。文章详细介绍了继承的基本概念、定义格式、继承方式(public、protected、private)、赋值兼容转换、作用域问题、默认成员函数规则、继承与友元、静态成员、多继承及菱形继承问题,并对比了继承与组合的优缺点。最后总结指出,虽然继承提高了代码灵活性和复用率,但也带来了耦合度高的问题,建议在“has-a”和“is-a”关系同时存在时优先使用组合。
35 6
|
26天前
|
编译器 C语言 C++
类和对象的简述(c++篇)
类和对象的简述(c++篇)
|
23天前
|
安全 编译器 C语言
【C++篇】深度解析类与对象(中)
在上一篇博客中,我们学习了C++类与对象的基础内容。这一次,我们将深入探讨C++类的关键特性,包括构造函数、析构函数、拷贝构造函数、赋值运算符重载、以及取地址运算符的重载。这些内容是理解面向对象编程的关键,也帮助我们更好地掌握C++内存管理的细节和编码的高级技巧。