C++学习 --stack

目录

[1, 什么是stack](#1, 什么是stack)

[2, 创建stack](#2, 创建stack)

[2-1, 标准数据类型](#2-1, 标准数据类型)

[2-2, 自定义数据类型](#2-2, 自定义数据类型)

[2-3, 其他创建方式](#2-3, 其他创建方式)

[3, 操作stack](#3, 操作stack)

[3-1, 赋值](#3-1, 赋值)

[3-2, 插入元素(push)](#3-2, 插入元素(push))

[3-3, 查询元素](#3-3, 查询元素)

[3-4, 删除元素](#3-4, 删除元素)

[3-5, 判断是否为空](#3-5, 判断是否为空)

[3-6, 交换](#3-6, 交换)

[3-7, 获取长度](#3-7, 获取长度)


1, 什么是stack

C++中的容器数据类型, 叫着栈容器 , 元素是先进后出, 只有顶部元素 支持操作,所以不支持遍历

2, 创建stack

通过stack**<数据类型> 对象名** , 可创建stack, 数据类型可以是标准数据类型 , 也可以是自定义类型

2-1, 标准数据类型

cpp 复制代码
//stack中元素数据类型为string
stack<string> s1;

2-2, 自定义数据类型

cpp 复制代码
//stack中元素的数据类型为Myclass
stack<Myclass> s1;

2-3, 其他创建方式

cpp 复制代码
stack<Myclass> s1;
//通过拷贝构造方式, 将一个已存在的s1, 拷贝给s2
stack<Myclass> s2(s1);

3, 操作stack

3-1, 赋值

由于stack是一个容器, 只支持将一个 stack赋值给另外一个stack

cpp 复制代码
stack<Myclass> s2 = s1;

3-2, 插入元素(push)

通过对象名.push(元素), 向stack中插入元素

cpp 复制代码
Myclass m1("aaa", 1);
Myclass m2("bbb", 2);
Myclass m3("ccc", 3);
stack<Myclass> s1;
s1.push(m1);
s1.push(m2);
s1.push(m3);

3-3, 查询元素

通过对象名 .top(), 获取栈顶元素

cpp 复制代码
Myclass m1("aaa", 1);
Myclass m2("bbb", 2);
Myclass m3("ccc", 3);
stack<Myclass> s1;
s1.push(m1);
s1.push(m2);
s1.push(m3);
cout << s1.top().m_name << endl;
cout << s1.top().m_age << endl;

3-4, 删除元素

通过对象名.pop(), 删除栈顶元素

cpp 复制代码
s1.pop();

3-5, 判断是否为空

可通过**对象名.empty(),**判断栈是否为空, 为空返回0, 不为空返回1

cpp 复制代码
cout << s1.empty() << endl;

3-6, 交换

可通过对象名1.swap(对象名2), 交换两个栈的元素

cpp 复制代码
s1.swap(s2);

3-7, 获取长度

可通过s1.size(), 删除栈顶元素

cpp 复制代码
cout << s1.size() << endl;
相关推荐
小龙报22 分钟前
《C语言疑难点 --- C语内存函数专题》
c语言·开发语言·c++·创业创新·学习方法·业界资讯·visual studio
卡提西亚1 小时前
C++笔记-21-运算符重载
c++·笔记
学习_学习_再学习1 小时前
ffmpeg学习记录
学习·ffmpeg
草莓熊Lotso1 小时前
C++ 继承特殊场景解析:友元、静态成员与菱形继承的底层逻辑
服务器·开发语言·c++·人工智能·经验分享·笔记·1024程序员节
利刃大大2 小时前
【动态规划:01背包】01背包详解 && 模板题 && 优化
c++·算法·动态规划·力扣·背包问题
im_AMBER2 小时前
算法笔记 10
笔记·学习·算法·leetcode
9ilk2 小时前
【基于one-loop-per-thread的高并发服务器】--- 前置技术
运维·服务器·c++·笔记·后端·中间件
苏比的博客4 小时前
Windows MFC添加类,变量,类导向
c++·windows·mfc
yudiandian20144 小时前
MFC - 使用 Base64 对图片进行加密解密
c++·mfc
qzhqbb4 小时前
神经网络—— 学习与感知器
神经网络·学习