【C++初阶】STL详解(七)Stack与Queue的模拟实现

简介: 【C++初阶】STL详解(七)Stack与Queue的模拟实现


容器适配器

stack和queue有一点需要注意的是,虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和queue只是对其他容器的接口进行了包装,STL中stack和queue默认使用deque容器。

在stack和queue的类模板声明当中我们就可以看到,它们的模板参数有两个,第一个是stack和queue当中所存储的元素类型,而另一个就是指定使用的容器类型。只不过当我们不指定使用何种容器的情况下,stack和queue都默认使用deque作为指定容器。

理解: 学过数据结构后我们都知道,stack和queue既可以使用顺序表实现,也可以使用链表实现。

在这里我们若是定义一个stack,并指定使用vector容器,则定义出来的stack实际上就是对vector容器进行了包装

stack的模拟实现:

知道了容器适配器后,stack的模拟实现就显得相当简单,我们只需要调用所指定容器的各个成员函数即可实现stack的各个函数接口。

模拟实现代码如下:

namespace NIC //防止命名冲突
{
  template<class T, class Container = std::deque<T>>
  class stack
  {
  public:
    //元素入栈
    void push(const T& x)
    {
      _con.push_back(x);
    }
    //元素出栈
    void pop()
    {
      _con.pop_back();
    }
    //获取栈顶元素
    T& top()
    {
      return _con.back();
    }
    const T& top() const
    {
      return _con.back();
    }
    //获取栈中有效元素个数
    size_t size() const
    {
      return _con.size();
    }
    //判断栈是否为空
    bool empty() const
    {
      return _con.empty();
    }
    //交换两个栈中的数据
    void swap(stack<T, Container>& st)
    {
      _con.swap(st._con);
    }
  private:
    Container _con;
  };
}

测试一下:

queue的模拟实现:

同样的方式,我们也是通过调用所指定容器的各个成员函数来实现queue的。

模拟实现代码如下:

namespace NICO //防止命名冲突
{
  template<class T, class Container = std::deque<T>>
  class queue
  {
  public:
    //队尾入队列
    void push(const T& x)
    {
      _con.push_back(x);
    }
    //队头出队列
    void pop()
    {
      _con.pop_front();
    }
    //获取队头元素
    T& front()
    {
      return _con.front();
    }
    const T& front() const
    {
      return _con.front();
    }
    //获取队尾元素
    T& back()
    {
      return _con.back();
    }
    const T& back() const
    {
      return _con.back();
    }
    //获取队列中有效元素个数
    size_t size() const
    {
      return _con.size();
    }
    //判断队列是否为空
    bool empty() const
    {
      return _con.empty();
    }
    //交换两个队列中的数据
    void swap(queue<T, Container>& q)
    {
      _con.swap(q._con);
    }
  private:
    Container _con;
  };
}

测试一下:

相关文章
|
5天前
|
C++ 容器
C++之Queue容器
C++之Queue容器
10 3
|
5天前
|
C++ 容器
C++之stack容器
C++之stack容器
14 1
|
5天前
|
C++ 容器
C++ STL标准库 《map容器详解》
C++ STL标准库 《map容器详解》
10 0
|
5天前
|
存储 C++ 容器
C++ STL标准库 《map容器详解》
C++ STL标准库 《map容器详解》
12 0
|
5天前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
14 0
|
6天前
|
C++ 容器
【C++航海王:追寻罗杰的编程之路】queue
【C++航海王:追寻罗杰的编程之路】queue
9 0
|
3天前
|
C++
【C++】日期类Date(详解)②
- `-=`通过复用`+=`实现,`Date operator-(int day)`则通过创建副本并调用`-=`。 - 前置`++`和后置`++`同样使用重载,类似地,前置`--`和后置`--`也复用了`+=`和`-=1`。 - 比较运算符重载如`&gt;`, `==`, `&lt;`, `&lt;=`, `!=`,通常只需实现两个,其他可通过复合逻辑得出。 - `Date`减`Date`返回天数,通过迭代较小日期直到与较大日期相等,记录步数和符号。 ``` 这是236个字符的摘要,符合240字符以内的要求,涵盖了日期类中运算符重载的主要实现。
|
5天前
|
C++
C++职工管理系统(类继承、文件、指针操作、中文乱码解决)
C++职工管理系统(类继承、文件、指针操作、中文乱码解决)
7 0
C++职工管理系统(类继承、文件、指针操作、中文乱码解决)
|
3天前
|
存储 编译器 C++
【C++】类和对象④(再谈构造函数:初始化列表,隐式类型转换,缺省值
C++中的隐式类型转换在变量赋值和函数调用中常见,如`double`转`int`。取引用时,须用`const`以防修改临时变量,如`const int& b = a;`。类可以有隐式单参构造,使`A aa2 = 1;`合法,但`explicit`关键字可阻止这种转换。C++11起,成员变量可设默认值,如`int _b1 = 1;`。博客探讨构造函数、初始化列表及编译器优化,关注更多C++特性。
|
3天前
|
编译器 C++
【C++】类和对象④(类的默认成员函数:取地址及const取地址重载 )
本文探讨了C++中类的成员函数,特别是取地址及const取地址操作符重载,通常无需重载,但展示了如何自定义以适应特定需求。接着讨论了构造函数的重要性,尤其是使用初始化列表来高效地初始化类的成员,包括对象成员、引用和const成员。初始化列表确保在对象创建时正确赋值,并遵循特定的执行顺序。