C++标准库类模板(stack)和 队列(queue)
在C++标准库(STL)中有栈和队列的类模板,因此可以直接使用
1、栈(stack):使用栈之前,要先包含头文件 : #include<stack>
stack.push(elem); //往栈头添加元素
stack.pop(); //从栈头移除第一个元素
stack.top(); //返回栈顶元素
stack.empty(); //判断堆栈是否为空,栈空返回true,栈非空返回false
stack.size(); //返回堆栈的大小
例:
#include <iostream>
#include <stack>
using namespace std;
int main(){
stack<int> stack;
int num;
cout<<"入栈:";
for(int i = 1;i<10;i++){
cout<<i<<" ";
stack.push(i);
}
stack.empty()?cout<<endl<<"当前栈空":cout<<endl<<"当前栈非空";
cout<<endl<<"栈内元素数:"<<stack.size()<<endl;
cout<<"出栈:";
while(!stack.empty())
{
cout<<stack.top()<<" ";
stack.pop();
}
stack.empty()?cout<<endl<<"当前栈空":cout<<endl<<"当前栈非空";
return 0;
}
2、队列(queue):使用队列,要先包含头文件 : #include<queue>
queue.push(elem) //把元素压入队列尾部
queue.pop() //删除队首元素,但不返回
queue.front() //返回队首元素,但不删除
queue.back() //返回队尾元素,但不删除
queue.size() //返回队列中元素的个数
queue.empty() //检查队列是否为空,如果为空返回true,否则返回false
例:
#include <iostream>
#include <queue>
using namespace std;
int main(){
queue<int> queue;
int num;
cout<<"入队:";
for(int i = 1;i<10;i++){
queue.push(i);
cout<<queue.back()<<" ";
}
queue.empty()?cout<<endl<<"当前队列空":cout<<endl<<"当前队列非空";
cout<<endl<<"队列内元素数:"<<queue.size()<<endl;
cout<<"出队:";
while(!queue.empty())
{
cout<<queue.front()<<" ";
queue.pop();
}
queue.empty()?cout<<endl<<"当前队列空":cout<<endl<<"当前队列非空";
return 0;
}
C++标准库类模板(stack)和 队列(queue)的更多相关文章
- C++标准库类模板vector
vector是C++标准库STL中的一个重要的类模板,相当于一个更加健壮的,有很多附加能力的数组 使用vector前首先要包含头文件 #include<vector> 1.vector的 ...
- ZT 类模板Stack的实现 by vector
*//*第3章 类模板 与函数相似,类也可以被一种或多种类型参数化.容器类就是一个具有这种特性的典型例子,它通常被用于管理某种特定类型的元素.只要使用类模板,你就可以实现容器类,而不需要确定容器中元素 ...
- C++ Templates (2.1 类模板Stack的实现 Implementation of Class Template Stack)
返回完整目录 目录 2.1 类模板Stack的实现 Implementation of Class Template Stack 2.1.1 声明类模板 Declaration of Class Te ...
- STL学习笔记6 -- 栈stack 、队列queue 和优先级priority_queue 三者比较
栈stack .队列queue 和优先级priority_queue 三者比较 默认下stack 和queue 基于deque 容器实现,priority_queue 则基于vector 容器实现 ...
- C++标准库分析总结(五)——<Deque、Queue、Stack设计原则>
本节主要总结标准库Deque的设计方法和特性以及相关迭代器内部特征 1.Deque基本结构 Deque(双向队列)也号称连续空间(其实是给使用者一个善意的谎言,只是为了好用),其实它使用分段拼接起来的 ...
- python基本数据结构栈stack和队列queue
1,栈,后进先出,多用于反转 Python里面实现栈,就是把list包装成一个类,再添加一些方法作为栈的基本操作. 栈的实现: class Stack(object): #初始化栈为空列表 def _ ...
- C++栈(stack)、队列(queue)、链表(list)的常用函数
C++队列Queue是一种容器适配器,它给予程序员一种先进先出(FIFO)的数据结构.1.back() 返回一个引用,指向最后一个元素2.empty() 如果队列空则返回真3.front() 返回第一 ...
- 06.队列、python标准库中的双端队列、迷宫问题
class QueueUnderflow(ValueError): """队列为空""" pass class SQueue: def __ ...
- 标准库中的-stack
#include <sequence_concepts.h> __STL_BEGIN_NAMESPACE // Forward declarations of operators == a ...
随机推荐
- linux tomcat自动部署shell
#!/bin/bash #defined TOMCAT_HOME="/usr/java/tomcat/tomcat" TOMCAT_PORT=80 PROJECT ...
- PHP 5.2 5.3 5.4 5.5 memcache dll扩展
在windows下PHP5.2版本的memcache扩展dll文件好找,5.3的可能不是很好找,这里提供PHP5.2.5.3.5.4.5.5的php_memcache.dll扩展,需要的可以下载. 全 ...
- C++/Java中继承关系引发的调用关系详解
C++: 这里引用到了 http://blog.csdn.net/haoel/article/details/1948051/ 中的内容,还请提前阅读陈大神的这篇博客后在阅读本篇. 覆盖,实现多态的基 ...
- Mysql的备份,权限与日志
1>Mysql的数据备份 mysqldump 工具 --single-transaction 该选项导出数据之前提交一个BEGIN SQL语句,不会阻塞任何应该程序而且能保证导出数据时的一 ...
- [VSTO] warning CS0467 解决方案
warning CS0467: Ambiguity between method 'Microsoft.Office.Interop.Word._Document.Close(ref object, ...
- 萌新web前端从零开始(1)——计算机入门
前言:这是一个萌新从零开始的学习之路,与大家分享自己的看法与见解,还请指出错误与遗漏点方便改正. 1.认识计算机. 计算机语言常见的有C,PHP,Ruby,Java,C#,Basic,JS,C++等, ...
- HTTP杂项
HTTP请求头中的origin, referer和host三个字段的区别 host 描述请求将被发送的目的地,包括,且仅仅包括域名和端口号 在任何类型请求中,request都会包含此header信息. ...
- 【QTP专题】04_对象及操作方法
本节介绍知识点包括 1.QTP自动化的原理 2.两类对象:TO(测试对象).RO(运行对象) 3.操作方法:SetTOProperty,GetROProperty,GetTOProperty 1.QT ...
- 「HNOI 2014」 江南乐
\(Description\) \(n\)堆石子,每堆石子有\(s_i\)个,两个人轮流操作,每次可以将一对不少于\(F\)的石子尽量平均分成\(m\)堆,\(m\)每次自选,不能操作者输.共有\(T ...
- OCP 12c最新考试原题及答案(071-3)
3.(4-10) choose the best answer:The user SCOTT who is the owner of ORDERS and ORDER_ITEMS tables iss ...