Stack容器

Stack栈容器是Vector容器的子类,它实现了一个便准的后进先出(LIFO:Last In Frist Out)的栈。

Stack的特点是后进先出。它通过5个操作方法对Vector进行扩展,允许将向量视为堆栈。

操作栈的方法:

empty()//测试这个栈是否为空

peek()//查看堆栈顶部元素

pop()//删除这个堆栈的顶部对象,并且返回该对象的值函数

push(E item)//压栈的过程

search(object o)//根据元素在栈中查找元素对应的位置,若找到则返回对应的位置,若无返回-1

将元素添加到栈容器中

获取栈中的元素:(遵循先进后出的原则)

判断栈是否为空:

 查看栈顶顶部元素:(只是查看,并不删除栈顶元素,用法与pop()方法不同)

返回指定元素在容器中的位置:

 在栈容器中,计数是从栈顶开始以1,2,3,...计的。

 

 

 

### C++ STL `stack` 容器常用操作及示例 #### 构造函数与基本概念 `std::stack` 是 C++ 标准模板库 (STL) 中的一个适配器容器,它提供了后进先出(LIFO, Last In First Out)的数据结构。该容器基于其他序列容器(如 `deque`, `vector` 或者 `list`),默认情况下使用的是 `deque`。 #### 基本成员函数介绍 - **构造函数** 可以通过指定底层容器来创建一个新的实例[^5]。 - **赋值操作** 支持复制赋值语义,即可以通过重载等号操作符实现两个之间的赋值[^1]: ```cpp stack& operator=(const stack &stk); ``` - **入 (`push`) 和 出 (`pop`)** 使用 `push()` 方法可以向顶添加新元素;而 `pop()` 则用于移除当前位于顶的元素。需要注意的是,`pop()` 不返回任何值,如果想要获取被弹出的元素,则应该在此之前调用 `top()` 获取其副本[^2]: ```cpp s.push(value); // 将 value 添加到顶 s.pop(); // 移除顶元素 ``` - **访问顶元素 (`top`)** 当不为空时,可通过 `top()` 访问最上面的那个元素: ```cpp T& top(); const T& top() const; ``` - **判断是否为空 (`empty`)** 调用此方法可检测内是否有剩余项存在: ```cpp bool empty() const noexcept; ``` - **查询大小 (`size`)** 返回中存储了多少个元素。注意并非所有版本都支持这个功能,在某些编译环境下可能不可用或者效率较低,因此建议谨慎使用: ```cpp size_type size() const; ``` #### 示例代码展示 下面给出一段完整的程序演示如何利用上述提到的各种接口完成简单的堆管理任务: ```cpp #include <iostream> #include <stack> using namespace std; int main(){ // 创建 stack 对象并执行一系列操作 std::stack<int> myStack; // 入测试 for(int i = 0 ; i<3 ; ++i){ cout << "Pushing element: "<< i+1<< endl; myStack.push(i + 1); } // 查看的状态 cout<<"\nCurrent Stack Status:"<<endl; while(!myStack.empty()){ cout<<"Top Element is :"<<myStack.top()<<endl; myStack.pop(); } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值