参考:http://www.weixueyuan.net/view/6405.html

总结:  

  容器适配器是用基本容器实现的一些新容器,这些容器可以用于描述更高级的数据结构。

  容器适配器有三种:stack、queue和priority_queue。  

  stack可以与数据结构中的栈对应,它具有先进后出的特性,

  而queue则可以理解为队列,它具有先进先出的特性,

  priority_queue则是带优先级的队列,其元素可以按照某种优先级顺序进行删除。

  对于stack,push为入栈操作即向栈中添加元素,pop为出栈操作即删除栈顶元素,top函数则为返回栈顶元素但是并不删除它,empty函数则用于判断栈是否为空,若为空则返回true,否则返回false。

  默认情况下stack容器衍生自deque,如果我们想从vector衍生出stack容器则需要按照如下方式进行定义:stack < int, vector < int > > s;

  对于queue容器而言,它同样默认是衍生自deque容器的。

  priority_queue容器提供了top函数用于访问下一个元素,访问但不删除。对于整型的优先队列而言,默认是按照数据从大到小的顺序删除元素的。

---------------------------------

容器适配器是用基本容器实现的一些新容器,这些容器可以用于描述更高级的数据结构。容器适配器有三种:stack、queue和priority_queue。stack可以与数据结构中的栈对应,它具有先进后出的特性,而queue则可以理解为队列,它具有先进先出的特性,priority_queue则是带优先级的队列,其元素可以按照某种优先级顺序进行删除。

例1:

#include <iostream>
#include <stack>
using namespace std; int main()
{
stack< int > s;
int a;
while(cin >> a)
{
s.push(a);
}
while( !s.empty() )
{
a = s.top();
s.pop();
cout<< a <<endl;
}
return ;
}

本例是一个stack的示例程序,我们在主函数中定义了一个stack容器实体s,之后我们定义了一个变量a,我们用一个while循环向容器s中添加数据。之后再利用一个while循环将元素都出栈并打印显示。对于stack,push为入栈操作即向栈中添加元素,pop为出栈操作即删除栈顶元素,top函数则为返回栈顶元素但是并不删除它,empty函数则用于判断栈是否为空,若为空则返回true,否则返回false。

默认情况下stack容器衍生自deque,当我们定义一个stack容器实例时:

stack < int > s;

它其实等价于:

stack < int, deque < int > > s;

如果我们想从vector衍生出stack容器则需要按照如下方式进行定义:

stack < int, vector < int > > s;

例2:

#include <iostream>
#include <queue>
using namespace std; int main()
{
queue < int > q;
int a;
while(cin >> a)
{
q.push(a);
}
while( !q.empty() )
{
a = q.front();
q.pop();
cout<< a <<endl;
}
return ;
}

本例是queue容器的一个示例程序,对于queue容器而言,它同样默认是衍生自deque容器的。与stack容器相同,queue同样有push、pop函数用于插入和删除元素,只不过不同的是stack只能操作栈顶,而queue是在队列尾部插入元素,在队列头部删除元素。stack容器用top函数访问栈顶元素,而queue没有栈顶这么一说,因而也就没有top函数了,我们想访问队列头的元素可以使用front函数,该函数只是访问并不删除元素。empty函数同样可以用于判断队列queue是否为空。

例3:

#include <iostream>
#include <queue>
using namespace std; int main()
{
priority_queue < int > p; int a;
while(cin >> a)
{
p.push(a);
}
while( !p.empty() )
{
a = p.top();
p.pop();
cout << a <<" ";
}
cout << endl;
return ;
}

本例是priority_queue容器的示例程序,使用priority_queue容器我们只需要包含头文件queue就可以了。同样priority_queue容器可以用push和pop函数来插入和删除元素,priority_queue容器提供了top函数用于访问下一个元素,访问但不删除。对于整型的优先队列而言,默认是按照数据从大到小的顺序删除元素的。程序运行情况如下:

1 89 23 43 54 32 65 0 8 18 67 +↙
89 67 65 54 43 32 23 18 8 1 0

7.8 C++容器适配器的更多相关文章

  1. C++ Primer : 第九章 : vector变长、string的其他操作以及容器适配器

    vector变长机制.string的其他构造方法,添加.替换和搜索操作,string比较和数值转换,最后是容器适配器. vector对象是如何增长的 vector和string类型提供了一些成员函数, ...

  2. c++ 顺序容器学习 - 容器适配器

    摘要: 对 容器适配器 的疑问. 刚开始接触 容器适配器 时,总感觉怪怪的,认为多此一举,顺手搜了搜,原来我在这一点is not alone: STL容器适配器的用途 其中有个老兄说的好,这里 引用一 ...

  3. C++顺序性容器、关联性容器与容器适配器

    什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...

  4. C++ Primer 学习笔记_33_STL实践与分析(7) --容器适配器

    STL实践与分析 --容器适配器 引: 除了顺序容器.标准库还提供了三种顺序容器适配器:queue,priority_queue和stack.适配器是标准库中的概念.包含容器适配器,迭代器适配器和函数 ...

  5. STL之容器适配器queue的实现框架

    说明:本文仅供学习交流,转载请标明出处,欢迎转载! 上篇文章STL之容器适配器stack的实现框架已经介绍了STL是怎样借助基础容器实现一种经常使用的数据结构stack (栈),本文介绍下第二种STL ...

  6. STL之容器适配器stack的实现框架

    说明:本文仅供学习交流,转载请标明出处,欢迎转载! 一提到适配器(adapter).我们就想到了早期用电话线上网所用的调制解调器,俗称"猫"."猫"的作用是实现 ...

  7. c++ STL容器适配器

    一.标准库顺序容器适配器的种类     标准库提供了三种顺序容器适配器:queue(FIFO队列).priority_queue(优先级队列).stack(栈)   二.什么是容器适配器     &q ...

  8. C++ 容器:顺序性容器、关联式容器和容器适配器

    什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...

  9. 顺序容器----顺序容器操作,vector对象如何增长,额外的string操作,容器适配器

    一.顺序容器操作 1.向顺序容器添加元素 向顺序容器(array除外)添加元素的操作: 操作 说明 c.push_back(t) 在c的尾部创建一个值为t的元素.返回void c.emplace_ba ...

随机推荐

  1. JS 日期比较方法

    1.日期参数格式:yyyy-mm-dd // a: 日期a, b: 日期b, flag: 返回的结果 function duibi(a, b,flag) { var arr = a.split(&qu ...

  2. c# 正则表达式如何处理换行符?

    我们要分析网页,把整个网页内容作为匹配源,但是c#的正则表达式是默认以一行为单位的,使用 RegexOptions.Multiline 也没有实质性作用(它知识改变了^和$的行为) 只要在正则表达式前 ...

  3. 利用Vistual Studio自带的xsd.exe工具,根据XML自动生成XSD

    利用Vistual Studio自带的xsd.exe工具,根据XML自动生成XSD 1, 命令提示符-->找到vs自带的xsd.exe工具所在的文件夹 例如: C:\Program Files ...

  4. 【消息队列】从各方面比较下kafka、activemq、rabbitmq、rocketmq之间的区别

    一.单机吞吐量ActiveMQ:万级,吞吐量比RocketMQ和Kafka要低了一个数量级RabbitMQ:万级,吞吐量比RocketMQ和Kafka要低了一个数量级RocketMQ:10万级,Roc ...

  5. Vue Authentication And Route Handling Using Vue-router(详解)

    英文原文  (本文原出处),本博在原文的基础上,进一步分析代码的结构和解释代码. git 代码 创建一个app:  vue-router-auth 本文详解了如何使用vue-router建立路由记录对 ...

  6. Redis之下载安装及基本使用

    redis window系统的redis是微软团队根据官方的linux版本高仿的 官方原版: https://redis.io/ 中文官网:http://www.redis.cn 1.1 redis下 ...

  7. 简单记录下3PC

    三PC分为三个阶段:CanCommit,PreCommit, DoCommit 整个分布式系统中,有一个组织者,其他属于参与者,当一个组织者挂了,会从其他可用site中选一个组织者出来,降低阻塞,避免 ...

  8. Kindergarten CodeForces - 484D (贪心,好题)

    大意: 给定序列, 求划分为若干段, 使得总贡献最大, 每段的贡献为max-min 可以发现最优解一定是连续一段递增或递减, 然后dp即可. #include <iostream> #in ...

  9. laravel项目数据库交互逻辑

    一般在获取数据库数据的时候,我们会使用get().或者first()来获取数据,但是在做一个项目的时候我使用了first()->toArray(),然后就报错了,鉴于此就好好的研究了get和fi ...

  10. java把list分成几个list

    public static void main(String[] args) { List<String> list=new ArrayList<>(); list.add(& ...