C++提高编程---3.6 STL-常用容器-queue 容器【P213~P214】

C++提高编程---3.6 STL-常用容器-queue 容器【P213~P214】

    • [3.6 queue 容器](#3.6 queue 容器)
      • [3.6.1 queue 容器基本概念](#3.6.1 queue 容器基本概念)
      • [3.6.2 queue 容器常用接口](#3.6.2 queue 容器常用接口)

3.6 queue 容器

3.6.1 queue 容器基本概念

概念:Queue是一种先进先出(First In First Out,FIFO)的数据结构,它有两个出口

  • 队头只能出 pop()
  • 队尾只能进 push()

只有队头、队尾能被外界访问,因此不能有遍历行为

3.6.2 queue 容器常用接口

cpp 复制代码
#include<iostream>
#include<queue>
#include<string>


using namespace std;

// 队列 queue

class Person {
public:
	Person(string name, int age) {
		this->name_ = name;
		this->age_ = age;
	}
		
	string name_;
	int age_;
};

void test01() {
	queue<Person> q;
	 
	// 准备数据
	Person p1("唐僧", 30);
	Person p2("孙悟空", 1000);
	Person p3("猪八戒", 900);
	Person p4("沙僧", 800);

	// 如队
	q.push(p1);
	q.push(p2);
	q.push(p3);
	q.push(p4);

	cout << "当前队列长度为:" << q.size() << endl;


	// 判断队列不为空,查看队头队尾,出队
	while (!q.empty()) {
		cout << "队头为:姓名------" << q.front().name_ << "年龄------" << q.front().age_ << endl;
		cout << "队尾为:姓名------" << q.back().name_ << "年龄------" << q.back().age_ << endl;
		// 出队
		q.pop();
		// 查看队列大小
		cout << "当前队列长度为:" << q.size() << endl;
	}

}

int main() {
	
	test01();

	system("pause");
	return 0;
}
相关推荐
ID_180079054736 小时前
小红书评论 API 接口详解与实战开发
java·jvm·c++
khalil10207 小时前
代码随想录算法训练营Day-58 图论08 | 拓扑排序精讲、dijkstra(朴素版)精讲
c++·算法·图论·dijkstra·拓扑排序·prim·最短距离
丘山望岳8 小时前
藤萝垂序——二叉搜索树
开发语言·数据结构·c++
光电笑映8 小时前
深入理解 ELF:从目标文件到程序加载的全过程
linux·运维·服务器·c++
lynnlovemin9 小时前
【信息学竞赛专题】滑动窗口(尺取法)超全详解|C++模板+经典例题+避坑指南
开发语言·c++·算法·滑动窗口·信息学竞赛
不会C语言的男孩9 小时前
VS Code 中搭建 C/C++ 开发环境(MSYS2 编译器)
c语言·c++
似水এ᭄往昔9 小时前
【Qt】--Qt概述
开发语言·c++·qt
澈2079 小时前
动态规划入门:从斐波那契到爬楼梯
c++·算法
不会C语言的男孩9 小时前
C++ Primer Plus 第3章:处理数据
开发语言·c++