STL之stack

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

有元素推入栈的操作称为:push,将元素推出stack的操作称为pop.

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

stack的用法

//构造
stack<T> stkT;//stack采用模板类实现, stack对象的默认构造形式
stack(const stack &stk);//拷贝构造函数

//赋值
stack& operator=(const stack &stk);//重载等号操作符

//存取
push(elem);//向栈顶添加元素
pop();//从栈顶移除第一个元素
top();//返回栈顶元素

//大小
empty();//判断堆栈是否为空
size();//返回堆栈的大小

//C++11中添加
emplace(elem,...);//emplace直接传入Node的构造函数的参数,并将构造的元素加入栈中;省去了构造临时对象,减少了内存开销
swap();//swap将两个 stack的内容交换.这两个 stack的模板参数 T和 Container必须都相同