【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

目录
相关文章
|
1月前
|
存储 程序员 C++
C++常用基础知识—STL库(2)
C++常用基础知识—STL库(2)
68 5
|
30天前
|
存储 算法 调度
【C++打怪之路Lv11】-- stack、queue和优先级队列
【C++打怪之路Lv11】-- stack、queue和优先级队列
32 1
|
1月前
|
存储 自然语言处理 程序员
C++常用基础知识—STL库(1)
C++常用基础知识—STL库(1)
52 1
|
1月前
|
设计模式 存储 C++
C++之stack 和 queue(下)
C++之stack 和 queue(下)
33 1
|
1月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
22 0
|
1月前
|
C++ 容器
C++之stack 和 queue(上)
C++之stack 和 queue(上)
55 0
|
6天前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
29 4
|
7天前
|
存储 编译器 Linux
【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)
本文介绍了C++中的类和对象,包括类的概念、定义格式、访问限定符、类域、对象的创建及内存大小、以及this指针。通过示例代码详细解释了类的定义、成员函数和成员变量的作用,以及如何使用访问限定符控制成员的访问权限。此外,还讨论了对象的内存分配规则和this指针的使用场景,帮助读者深入理解面向对象编程的核心概念。
26 4
|
30天前
|
存储 编译器 对象存储
【C++打怪之路Lv5】-- 类和对象(下)
【C++打怪之路Lv5】-- 类和对象(下)
27 4
|
30天前
|
编译器 C语言 C++
【C++打怪之路Lv4】-- 类和对象(中)
【C++打怪之路Lv4】-- 类和对象(中)
23 4