STL__queue_的应用
转:http://hi.baidu.com/xiaotiandm/item/bda34511cf9e99098fbde41a
调用的时候要有头文件: #include<stdlib.h> 或 #include<cstdlib> + #include<queue>
详细用法:
定义一个queue的变量 queue<Type> que
查看是否为空范例 que.empty() 是的话返回1,不是返回0;
从已有元素后面增加元素(入队) que.push()
现有元素的个数 que.size()
显示第一个元素 que.front()
显示最后一个元素 que.back()
清除第一个元素 (出队) que.pop()
看一个例子:
#include <cstdlib>
#include <iostream>
#include <queue>
using namespace std;
int main()
{
queue<int> myQ;
cout<< "现在 queue 是否 empty? "<< myQ.empty() << endl;
cout << "push 5, push 6, push 7" << endl;
myQ.push(5);
myQ.push(6);
myQ.push(7);
cout << "现在 queue 的元素有几个? " << myQ.size() << endl;
cout << "现在 queue 的front为何? " << myQ.front() << endl;
cout << "现在 queue 的rear为何? " << myQ.back() << endl;
cout << "pop" << endl; myQ.pop();
cout << "现在 queue 的元素有几个? " << myQ.size() << endl;
cout << "现在 queue 的front为何? " << myQ.front() << endl;
cout << "现在 queue 的rear为何? " << myQ.back() << endl;
system("PAUSE");
return 0;
}
关于队列的知识;
使用queue之前,要先利用构造函数一个队列对象,才可以进行元素的入队,出队,取队首和队尾等操作;
(1)、queue() queue<int> q; 或者 queue<int>Q[10000];
(2)、queue(const queue&) 复制构造函数
例如:用一行代码利用queue对象q1,创建一个以双向链表为底层容器的queue对象q2
queue<int,list<int>>q1;
queue<int,list<int>>q2(q1);
(3)、元素入队 函数为:push()例如:q.push(3),意思是将3入队 ,注意队列的大小不预设
(4)、元素出队 函数为:pop()例如:q.pop()
(5)、取对头元素 函数为:front()
(6)、取队尾元素 函数为:back()
(7)、判断对空 函数为:empty()
(8)、队列的大小 函数为:size()返回队列的当前元素的个数
(9)、如何实现固定大小的queue队列
在每一次元素入队列前都判断当前的队列是否满,用双向链表做queue 的底层容器可以实现
例如:
#include<iostream>
#include<list>
#include<queue>
using namespace std;
#define QUEUE_SIZE 50 //固定大小;
int main()
{
queue<int,list<int>> q;
if(q.size(QUEUE_SIZE) )
q.push(51);
if(q.size(QUEUE_SIZE) )
q.push(36);
if(q.size(QUEUE_SIZE))
q.push(28);
while(!q.empty() )
{
cout<<q.front()<<endl;
q.pop();
}
return 0;
}
#include<iostream>
#include<cstdio>
#include<queue>
#include<stdlib>
using namespace std;
int main()
{
register int i,j;
int m,n;
char c[6];
int x,y;
while(scanf("%d %d",&n,&m)!=EOF)
{
queue<int> Q[10000];
for(i=1;i<m;i++)
{
scanf("%s",&c);
if(strcmp(c,"INT") == 0)
{
for(j=1;j<=n;j++)
{
while(!Q[j].empty())
{
Q[j].pop();
}
continue;
}
}
if(strcmp(c,"PUSH")==0)
{
scanf("%d %d",&x,&y);
Q[x].push(y);
continue;
}
if(strcmp(c,"POP")==0)
{
scanf("%d ",&y);
if(Q[y].empty)
{
printf("NULL\n");continue;
}
else
{
printf("%d\n",Q[y].front());
}
Q[y].pop;
}
}
}
return 0;
}
STL__queue_的应用的更多相关文章
- HDOJ1728 BFS【STL__queue_的应用】
STL__queue_的应用 调用的时候要有头文件: #include<stdlib.h> 或 #include<cstdlib> + #include<queue> ...
随机推荐
- 数据绑定以及Container.DataItem几种方式与使用方法分析
灵活的运用数据绑定操作 绑定到简单属性:<%#UserName%> 绑定到集合:<asp:ListBox id="ListBox1" ...
- Eclipse用法和技巧二十二:快速调整字体大小
团队代码review的时候,一般都会一堆人围着显示器,或者投影仪.这个时候调整代码字体大小就显得很重要.下面直接说操作方式. 步骤一:Windows -> Preference 步 ...
- javascript笔记整理(函数)
javascript函数的声明和调用将完成某一特定功能的代码集合起来,可以重复使用的代码块. 一.函数的声明方式(创建) A.基本语法(function 关键字)function 函数名([参数1] ...
- C# 未能加载文件或程序集“MySQLDriverCS..." 错误解决
在解决方案的属性里,生成,里面有个目标平台,网上说的 大概也就是64位和32位的不兼容问题..试着把目标平台改为X86后竟然神奇的正常了!
- Android SurfaceView实现静态于动态画图效果
本文是基于Android的SurfaceView的动态画图效果,实现静态和动态下的正弦波画图,可作为自己做图的简单参考,废话不多说,先上图, 静态效果: 动态效果: 比较简单,代码注释的也比较详细,易 ...
- CF 8D Two Friends (三分+二分)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题意 :有三个点,p0,p1,p2.有两个人ali ...
- 微软Ajax--UpdatePanel控件
今天用做日历显示本月的考勤记录,用到了UpdatePanel控件,才发现对这个控件并不太了解,所以找了点儿资料,整理了一下给大家发上来! 一.UpdatePanel的结构 <asp:Script ...
- 在JavaScript函数中使用EL表达式注意的事项
最近在使用JSP显示从Servlet带过来的数据时,大量的使用到了EL表达式,并且有些EL表达式是在使用到JavaScript的函数时作为参数传入的,举个例子,比如下面的样子: 这个HTML标签的意思 ...
- TestNg JAVA 自动化单元测试框架Demo
TestNg TestNg 是java的一个自动化单元测试框架 参考:http://testng.org/doc/index.html 环境准备 既然是java 的自动化单元测试框架,就必须要有jav ...
- TPanel的默认颜色存储在dfm中,读取后在Paint函数中设置刷子的颜色,然后填充整个背景
声明如下: TCustomPanel = class(TCustomControl) private FFullRepaint: Boolean; FParentBackgroundSet: Bool ...