前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++ STL容器之queue(队列)快速入门

C++ STL容器之queue(队列)快速入门

作者头像
可定
发布2020-04-20 15:07:01
5K0
发布2020-04-20 15:07:01
举报
文章被收录于专栏:细嗅蔷薇

queue,俗称为“队列”,在STL中主要则是实现了一个先进先出的容器。

使用queue需于代码头部添加#include,并且随后加上一句:using namespace std;即可。

queue的定义

queue<typename> name;

其中typename可以任意数据类型或容器

元素访问

由于队列是后进后出的数据结构,因此STL中的stack中只能通过front()来访问队首元素,或是通过back()来访问队尾元素。

获取队首元素

front():用以弹出栈顶元素,时间复杂度为O(1)。

获取队尾元素

back():用以弹出栈顶元素,时间复杂度为O(1)。

提示:使用front()和pop()函数前,必须用empty()判断队列是否为空,否则可能因为队空而出现错误。

将元素入队

push(x):将x入栈,时间复杂度为O(1)。

令队首元素出队

pop():用以弹出栈顶元素,时间复杂度为O(1)。

检测stack内是否为空

Empty():返回true为空,反之非空。

返回stack内元素的个数

size():时间复杂度为O(1)

代码

代码语言:javascript
复制
#include<stdio.h>
#include<queue>
using namespace std;
int main(){
    queue<int> q;
    if(q.empty()==true){//输出Empty
        printf("Empty\n");
    }else{
        printf("Not Empty\n");
    }
    for(int i = 1; i <= 5; i++){
        q.push(i);
    }
    for(int i = 1; i <= 3; i++){
        q.pop();
    }
    printf("%d\n",q.front());
    printf("%d\n",st.size());
}

常见用途

实现广度优先搜索。

实现广度优先搜索可以自己手动实现一个队列,也可以用queue作为代替(可以提高程序的准确性)

延伸

STL中还有几种容器与queue有关。

双端队列:首尾皆可插入和删除的队列 优先队列:使用对实现的默认将当前队列最大元素置于队首的容器

版权所有:可定博客 © WNAG.COM.CN

本文标题:《C++ STL容器之queue(队列)快速入门》

本文链接:https://cloud.tencent.com/developer/article/1616914

特别声明:除特别标注,本站文章均为原创,本站文章原则上禁止转载,如确实要转载,请电联:wangyeuuu@qq.com,尊重他人劳动成果,谢过~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • queue的定义
  • 元素访问
  • 获取队首元素
  • 获取队尾元素
  • 将元素入队
  • 令队首元素出队
  • 检测stack内是否为空
  • 返回stack内元素的个数
  • 代码
  • 常见用途
  • 延伸
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档