STL源码剖析-stack

本文介绍栈数据结构的概念及其实现方式,栈是一种先进后出的数据结构,仅允许在顶部进行操作。文章详细阐述了如何使用双端队列(deque)和链表(list)作为底层容器来实现栈,并解释了栈为何不支持遍历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.stack概述

stack是一种先进后出的数据结构,它只有一个出口。stack允许新增元素,移除元素,取得最顶端元素,但除了最顶端外,没有任何其它方法可以存取stack的其他元素。换言之,stack不允许有遍历行为

 

2. stack定义完整列表

        stack以deque为底部结构并封闭其头端开口,便轻而易举地形成了一个stack。SGI STL以deque作为默认情况下的stack底部结构,stack的实现因而非常简单

        由于stack以deque为底部容器完成其所有工作,所以stack也称为adapter适配器-"修改某物接口,形成另一种风貌"。stack不是容器,而是一种适配器。

        由于stack的代码十分简单,这里就完整列出:

#ifndef __SGI_STL_INTERNAL_STACK_H
#define __SGI_STL_INTERNAL_STACK_H

__STL_BEGIN_NAMESPACE

#ifndef __STL_LIMITED_DEFAULT_TEMPLATES
template <class T, class Sequence = deque<T> >
#else
template <class T, class Sequence>
#endif
class stack {
  friend bool operator== __STL_NULL_TMPL_ARGS (const stack&, const stack&);
  friend bool operator< __STL_NULL_TMPL_ARGS (const stack&, const stack&);
public:
  typedef typename Sequence::value_type value_type;
  typedef typename Sequence::size_type size_type;
  typedef typename Sequence::reference reference;
  typedef typename Sequence::const_reference const_reference;
protected:
  Sequence c;	// 底層容器
public:
  // 以下完全利用 Sequence c 的操作,完成 stack 的操作。
  bool empty() const { return c.empty(); }
  size_type size() const { return c.size(); }
  reference top() { return c.back(); }
  const_reference top() const { return c.back(); }
  // deque 是兩頭可進出,stack 是末端進,末端出(所以後進者先出)。
  void push(const value_type& x) { c.push_back(x); }
  void pop() { c.pop_back(); }
};

template <class T, class Sequence>
bool operator==(const stack<T, Sequence>& x, const stack<T, Sequence>& y) {
  return x.c == y.c;
}

template <class T, class Sequence>
bool operator<(const stack<T, Sequence>& x, const stack<T, Sequence>& y) {
  return x.c < y.c;
}

__STL_END_NAMESPACE

#endif /* __SGI_STL_INTERNAL_STACK_H */

3.stack没有迭代器
 

stack所有的元素的进出都必须符合"先进后出"的条件,只有stack顶端的元素,才有机会被外界取用。stack不提供遍历功能,也不提供迭代器。

4.以list作为stack的底层容器
 

就是所谓的链栈!

除了deque之外,list也是双向开口的数据结构。stack支持的函数有empty,size,back,push_back,pop_back,这些list都有。因此,可以以list为底部结构并封闭其头端开口,一样能够轻易形成一个stack。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值