stack容器的基本使用

这篇博客介绍了如何使用C++模板类实现一个Stack,并展示了其拷贝构造函数、赋值操作以及push、pop、top、empty和size等方法的用法。通过示例代码展示了如何使用Stack将整数的每一位按顺序输出,加深了对C++栈操作的理解。

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

构造函数:

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

赋值操作:

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

方法:

  • push(elem) //入栈
  • pop() //出栈
  • top() //获取栈顶元素
  • empty() //判断是否为空栈
  • size() //获取栈的大小

示例:

#include <iostream>
#include <stack>
using namespace std;

void f1(int num){  //将一个整数的每一位按顺序输出
    stack<int> s;  //使用时需指定栈元素的类型
    while(num){
        s.push(num % 10);
        num /= 10;
    }
    while(!s.empty()){
        cout << s.top() << " ";
        s.pop();  //pop方法没有返回值
    }
}

int main(){
    f1(12085);
}
### 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、付费专栏及课程。

余额充值