C++学习 --queue

目录

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

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

[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, 什么是queue

C++中的容器数据类型, 叫着队列容器 , 元素是先进先出, 不支持遍历

2, 创建queue

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

2-1, 标准数据类型

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

2-2, 自定义数据类型

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

2-3, 其他创建方式

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

3, 操作stack

3-1, 赋值

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

cpp 复制代码
queue<Myclass> q2 = q1;

3-2, 插入元素(push)

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

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

3-3, 查询元素

通过对象名.front(), 获取头部元素, 通过**对象名.back(),**获取尾部元素

cpp 复制代码
Myclass m1("aaa", 1);
Myclass m2("bbb", 2);
Myclass m3("ccc", 3);
queue<Myclass> q1;
queue<Myclass> q2;
q1.push(m1);
q1.push(m2);
q1.push(m3);
cout << q1.front().m_name << endl;
cout << q1.back().m_name << endl;

3-4, 删除元素

通过对象名.pop(), 删除头部元素

cpp 复制代码
q1.pop();

3-5, 判断是否为空

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

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

3-6, 交换

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

cpp 复制代码
q1.swap(q2);

3-7, 获取长度

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

cpp 复制代码
cout << q1.size() << endl;
相关推荐
王老师青少年编程22 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【跳跃与过河问题】:过河问题
c++·算法·贪心·csp·信奥赛·跳跃与过河问题·过河问题
是个西兰花23 分钟前
C++11:智能指针
开发语言·c++·智能指针·rall
CN-Dust40 分钟前
【C++专题】输出cout例题
开发语言·c++
Alice-YUE1 小时前
前端图片优化完全指南:从格式到加载的全面提速方案
前端·笔记·学习
沉默-_-1 小时前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法
Reese_Cool1 小时前
【STL】蓝桥杯/天梯赛终极杀器!10个C++字符串核心技巧,暴力破解高频考点
开发语言·c++·蓝桥杯·stl
我想我不够好。1 小时前
监控学习 4.28 1.5 hour
学习
Stella Blog1 小时前
狂神Java基础学习笔记Day05
java·笔记·学习
Alice-YUE1 小时前
前端性能优化完全指南:从指标到实战
前端·学习·性能优化
hehelm1 小时前
C++ 模拟实现 AVL 树
开发语言·c++