当前位置: 首页 > news >正文

C++——STL——队列(queue)

 队列的定义

队列(queue)是只允许在一端进行插入操作,在另一端进行删除操作线性表,允许插入

(也称入队、进队)的一端称为队尾,允许删除(也称出队)的一端称为队头

队列的示意图

队列中的元素除了具有线性关系外,还具有先进先出的特性。

栈的头文件

#include<queue>

栈的声明:queue<数据类型>变量名;

    queue<int>q1 ;//默认的构造函数queue<int>q2(q1);//拷贝构造函数queue<int>q3 = q1;//赋值

数据的存取

1.q1.push(element);入队

向队尾添加元素

2.q1.pop;出队

移除队头的第一个元素

3.q1.back();

返回最后一个元素,注意这里只是返回值,但并不删除

4.q1.front();

返回第一个元素,注意这里只是返回值,但并不删除

例子:

    q1.push(50);//向队尾添加元素q1.push(5);q1.push(13);//这个时候队列中元素为50 5 13q1.pop();//取队头元素50,这个时候栈中元素为5 13 cout << q1.back() << endl;//返回队尾元素13(但不删除)cout << q1.front() << endl;//返回队头元素5(但不删除)

大小操作

1.q1.empty();

如果是空,返回1;如果不是空,返回0

2..q1.size();

返回队列的大小

例子:

    //大小操作cout << q1.empty() << endl;//空返回1,不空返回0cout << q1.size() << endl;

习题

有一堆扑克牌,里面有n张扑克牌。第一次从牌堆顶上拿出一张牌并输出,第二次把牌放回牌堆底下。重复执行直到牌堆里没牌。也就是说奇数张的牌输出,偶数张的牌放回。

例子:

输入:

4

1 6 4 7

输出:

1 4 6 7

#include<iostream>
#include<queue>
using namespace std;
int main() {int n;//牌的个数cin >> n;queue<int>q;for (int i = 0; i < n; i++) {int j;cin >> j;//输入牌q.push(j);}//i为奇数,将牌输出;i为偶数,将牌放入队尾//直到牌数为0for (int i = 1,j=n; j > 0; j--,i++) {//i用来表示操作次数,j用来表示剩余牌数if (i % 2 == 1) {cout << q.front() << " ";q.pop();}else {q.push(q.front());q.pop();j++;//这个时候抽走的牌又放入了队尾,所以需要+1以抵消每次循环时候的-1}}return 0;
}


http://www.mrgr.cn/news/13094.html

相关文章:

  • DENCLUE算法原理及Python实践
  • 【STM32开发笔记】STM32H7S78-DK上的CoreMark移植和优化--兼记STM32上的printf重定向实现及常见问题解决
  • 线段树小例题——结合前后缀获得结果
  • 坐牢第三十天(c++)
  • IEEE T-ASLP | 利用ASR预训练的Conformer模型通过迁移学习和知识蒸馏进行说话人验证
  • 2024安卓iOS免签封装源码/解决APP误报毒/可打包和上传APP/自动实现5分钟随机更换签名
  • sdk监控平台
  • 破晓科技与神话:三防平板与《黑神话:悟空》的创新交响
  • 游戏发行技术体系框架图
  • 【C#】【EXCEL】Bumblebee/Classes/ExColumn.cs
  • 牛客D题连线
  • 构建一个资源控制面板:模拟 CPU 和内存负载
  • Qt | Qt是C++最好的图形界面开发库(学习路线图)
  • Java 入门指南:Map 接口
  • React——useRef()
  • vivado U_SET
  • 2024年第十五届蓝桥杯图形化省赛真题分享包含答案
  • World of Warcraft [CLASSIC][80][Grandel] Call to Arms: Strand of the Ancients
  • 力扣(坏了的计算机)
  • SSRF实现.SSH未创建写shell和SSRF漏洞之FastCGI利用