第三篇.

感觉队列和栈是必须的……所以决定加上这两个……

我发现我已经买域名买上隐了……今天又买了个.top……真是智障……

Queue(队列FIFO)和Statk(栈LIFO).

那么为什么要这两个一块讲呢?理由很简单,数据结构小班同志们都学了,基础原理都会了,这两个东西很像,无论是在操作上还是其他别的方面……

而这篇博客主要是详解STL中queue和statk的用法。

首先,回顾一下队列和栈:

  (1)     非STL的队列实现方法:

    用数组模拟一个队列,两个指针,分别指向队列的头和尾,入队++尾指针,队首出队++头指针;程序如下:

 int a[];
int tail=,head=;//tail:队尾指针,head:队首指针
/*队列尾进头出 FIFO(First In First Out)*/
void pop(){
head++;//头指针++,相当于弹出(删除)队首元素
}
void push(x){
tail++;
a[tail]=x;//在队尾添加元素
//a[tail++]=x;
}
int front(){
return a[head];//返回队首元素
}
int back(){
return a[tail];//返回队尾元素
}

其实这个样子,有可能因为头指针和尾指针超过了这个用来模拟队列的数组的大小,可能爆掉,所以,读者自行加个判断就好了(其实还有如果队列为空了再pop就会出错了(都是使用者的事),一本通上写的很明白了)

  (2)     非STL的栈实现方法:

    用数组模拟一个栈,一个头指针,指向栈顶,入栈++头指针,出栈—头指针;程序如下:

 int a[];
int t=;//栈顶指针
/*栈顶进栈顶出(好像腔肠动物:D),LIFO(Last In First Out)*/
void push(int x){
t++; //栈顶指针++
a[t]=x;//放进栈顶元素
//a[t++]=x;
}
void pop(){
t--;//栈顶元素--,相当于删掉栈顶元素
}
void top(){
return a[t];//返回栈顶指针指向的元素(栈顶元素)
}

OK,回顾完之前学的,现在让我们来看一下STL中队列和栈是怎么实现的:

(一) 队列

  1.普通队列:

    (1) 首先,通常,头文件是不可少的: #include<queue>

#include<queue>
queue<int> que;

    (2) 定义完了,入队出队操作(还记的刚刚上面非STL方式的例程中的函数名嘛):

que.push(a);//将变量a放到队列que的队尾,a入队。
que.pop();//弹出队列que的队首元素(删掉队首元素),队首出队

怎么样?就两句话,简不简单?

    (3) 其他操作:

 que.front();//将会返回队列que的队首元素
que.back();//将会返回队列que的队尾元素
que.size();//返回队列que的大小(目前队列有多少元素)
que.empty();//如果队列为空,则返回1,不为空则返回0

是不是很方便?

  2.优先队列:(优先队列其实就是普通队列加了个排序。操作上是跟普通队列一样的,不过队列中的元素是有序的)

  3.双端队列:(普通队列是跟只能在某一端进行入队另一端进行出队操作的(也就是队首和队尾),而双端队列可在队列两段都可进行入队出队操作)

(二) 栈

  1.    同上,头文件: #include<stack>

  2.    同上,入栈出栈操作:

  3.    同上,其他操作:

Gengxin讲STL系列——Queue和Stack的更多相关文章

  1. Gengxin讲STL系列目录

    引言:有人催我写关于STL的博客#(滑稽)        STL嘛,昨晚有人一直逼问我STL名字的由来——STL = Standard Template Library,标准模板库,惠普实验室开发的一 ...

  2. Gengxin讲STL系列——Set

    本系列第二篇blog 第一篇写的心潮澎湃,结果写完一看,这都是些什么玩意= =| Set的中文名称是“集合”.集合,高一数学必修一课本给出的定义已经很明确了,简单来讲就是一个不含重复元素的空间(个人定 ...

  3. Gengxin讲STL系列——String

    衔接上一篇引导. 作为第一篇博客,就要大气一点. 可我好像并不知道怎么才能让自己的博客大气一点= =: 明天是我生日,自己先买个中文域名庆祝了一下…… 好了,废话说完了,结果博客也没大气到哪去……,正 ...

  4. Scala 深入浅出实战经典 第39讲:ListBuffer、ArrayBuffer、Queue、Stack操作代码实战

    王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-64讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...

  5. STL总结之queue, priority_queue, stack

    之所以把这三个容器放在一起,是因为他们都是容器适配器.   STL中queue就是我们常用的FIFO队列,实现是一个容器适配器,这种数据结构在网络中经常使用.   queue的模板声明: templa ...

  6. STL之queue&stack使用简介

       queue 队列也是一个线性存储表,与后进先出的堆栈不同,元素数据的插入在表的一端进行,在另一端删除,从而构成了一个先进先出(First In First Out) 表.插入一端称为队尾,删除一 ...

  7. ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借

    ASP.NET MVC深入浅出系列(持续更新)   一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...

  8. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  9. 数据结构与算法(4) -- list、queue以及stack

    今天主要给大家介绍几种数据结构,这几种数据结构在实现原理上较为类似,我习惯称之为类list的容器.具体有list.stack以及queue. list的节点Node 首先介绍下node,也就是组成li ...

随机推荐

  1. 记一次令人发狂的 bug Eclipse 开不开 tomcat 7.0

    改项目,结果发现以前的项目也出了问题,就删除了系统用户下面workplace里的文件夹,结果,eclipse被清空,重新添加项目,发现一堆bug; 最让我崩溃的是,用tomcat 7.0跑项目,反复出 ...

  2. UWP开发小记

    针对个人的上一篇文章中提到的遇到的几个问题,做一下个人解答 DLL部署的问题,可以将DLL添加到工程中,属性中设置content为true,这样,部署目录下就会有这个文件. 需要说明的是,这个文件确实 ...

  3. Hadoop文件的基本操作

    Hadoop提供了大量的API对文件系统中的文件进行操作,主要包括: (1)读取文件 (2)写文件 (3)读取文件属性 (4)列出文件 (5)删除文件 1、读取文件 以下示例中,将hdfs中的一个文件 ...

  4. JSON基础知识

    1.什么是json •        JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) •        JSON 是轻量级的文本数据交换格式 ...

  5. js复制对象 和 节点类型和NodeList

    1. myList.cloneNode(true); 在参数为true的情况下,执行深复制,也就是复制节点及其整个子节点树,包括属性 2. myList.cloneNode(false); 在参数为f ...

  6. 织梦dedecms自定义字段在首页列表页文章页的调用

      1.首页调用. {dede:arclist addfields='字段英文名' channelid='模型ID' row='条数' type='栏目ID'}       [field:字段英文名/ ...

  7. [转]jQuery插件开发精品教程,让你的jQuery提升一个台阶

    原文链接:http://www.cnblogs.com/Wayou/p/jquery_plugin_tutorial.html 要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其 ...

  8. [算法导论]练习2-4.d求排列中逆序对的数量

    转载请注明:http://www.cnblogs.com/StartoverX/p/4283186.html 题目:给出一个确定在n个不同元素的任何排列中逆序对数量的算法,最坏情况需要Θ(nlgn)时 ...

  9. [TYVJ] P1002 谁拿了最多奖学金

    谁拿了最多奖学金 背景 Background NOIP2005复赛提高组第一题   描述 Description 某校的惯例是在每学期的期末考试之后发放奖学金.发放的奖学金共有五种,获取的条件各自不同 ...

  10. Managing TCP Connections in Dynamic Spectrum Access Based Wireless LANs

    2010年IEEE Secon的一篇文章.当然了,应该是之前就写好了,发表过,还是直接投到Secon了呢?直接投的吧,Secon不接受已发表过的吧. 本文的着笔点:有线网与DSAN(启用了DSA特性的 ...