下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第c++中queue用法超详细讲解(入门必看!)目录1、queue的作用2、queue的定义3、queue的成员函数总结
1、queue的作用
说到queue,大家一定会想到stack,同样是简单易用的数据结构之一。queue就是队列的意思,像大家日常排队一样,先排的人先用。stack则是相反的,后来的先用。这就有了queue先进先出,stack后进先出的说法。
queue是一个很简单的数据结构,但是却非常实用,同时也是必不可少的,其它的数据结构都无法替代队列。
queue常用于模仿队列,在算法中比较常用的有单调队列算法
相信看完本文就能上手使用了
2、queue的定义
queue储存的类型容器名
如:
储存int型数据的队列queueq;
储存double型数据的队列queueq;
储存string型数据的队列queueq;
储存结构体或者类的队列queue结构体名
3、queue的成员函数
back()//返回最后一个元素
empty()//如果队列空则返回真
front()//返回第一个元素
pop()//删除第一个元素
push()//在末尾加入一个元素
size()//返回队列中元素的个数
示例代码:
#includeiostream//c++标准头文件,可以使用cout,cin等标准库函数
#includequeue//使用queue时需要的头文件
usingnamespacestd;//命名空间,防止重名给程序带来各种隐患,使用cin,cout,stack,map,set,vector,queue时都要使用
intmain(){
queueint//定义一个int类型的队列
q.push(1);//在队尾添加元素1
q.push(2);//在队尾添加元素2
q.push(3);//在队尾添加元素3
cout"插入元素1、2、3后,目前队列中的元素:123"endl;
cout"q.size()="q.size()endl;//q.size()查看目前队列中的元素个数
cout"q.empty()="q.empty()endl;//查看队列是否为空,1即为空,0即非空
cout"q.front()="q.front()endl;//查看队首元素
coutendl;
q.pop();//队首元素出队
cout"q.pop()后,目前队列中的元素:23"endl;
cout"q.size()="q.size()endl;//q.size()查看目前队列中的元素个数
cout"q.empty()="q.empty()endl;//查看队列是否为空,1即为空,0即非空
cout"q.front()="q.front()endl;//查看队首元素
coutendl;
q.pop();//队首元素出队
cout"q.pop()后,目前队列中的元素:3"endl;
cout"q.size()="q.size()endl;//q.size()查看目前队列中的元素个数
cout"q.empty()="q.empty()endl;//查看队列是否为空,1即为空,0即非空
cout"q.front()="q.front()endl;//查看队首元素
coutendl;
q.pop();//队首元素出队
cout"q.pop()后,目前队列是空的"endl;
cout"q.size()="q.size()endl;//q.size()查看目前队列中的元素个数
cout"q.empty()="q.empty()endl;//查看队列是否为空,1即为空,0即非空
cout"队列是空的时候将不能用q.front()查看队首元素"endl;
运行结果:
插入元素1、2、3后,目前队列中的元素:123
q.size()=3
q.empty()=0
q.front()=1
q.pop()后,目前队列中的元素:23
q.size()=2
q.empty()=0
q.front()=2
q.pop()后,目前队列中的元素:3
q.size()=1
q.empty()=0
q.front()=3
q.pop()后,目前队列是空的
q.size()=0
q.empty()=1
队列是空的时候将不能用q.front()查看队首元素
queue和s
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 光刻技术原理
- 2025年高职地图数据图例转换技术(图例转换实操)试题及答案
- 2025年中职设备维护管理(管理技术)试题及答案
- 2025年中职服装与服饰设计(服饰教学实操)试题及答案
- 2025年高职房地产经营与管理(房地产经营与管理基础)试题及答案
- 2025年高职人力资源管理(招聘与配置)试题及答案
- 2025年高职河运海事管理(海事管理基础)试题及答案
- 2025年中职电子技术应用(电子电路基础)试题及答案
- 2025年大学环境科学(水污染控制实验)试题及答案
- 2025年中职第二学年(老年护理方向)照护实务阶段测试题及答案
- 章节复习:平行四边形(5个知识点+12大常考题型)解析版-2024-2025学年八年级数学下册(北师大版)
- 《实践论》《矛盾论》导读课件
- 中试基地运营管理制度
- 老年病康复训练治疗讲课件
- DB4201-T 617-2020 武汉市架空管线容貌管理技术规范
- 药品追溯码管理制度
- 脚手架国际化标准下的发展趋势
- 购销合同范本(塘渣)8篇
- 生鲜业务采购合同协议
- GB/T 4340.2-2025金属材料维氏硬度试验第2部分:硬度计的检验与校准
- 销售合同评审管理制度
评论
0/150
提交评论