STL有7中容器

分别为:

  vector  向量    <vector>(头文件)  随机访问容器、顺序容器

  deque  双端队列  <deque>       随机访问容器、顺序容器

  list     列表    <list>          可逆容器、顺序容器

  set     集合    <set>         可逆容器、关联容器

  multiset 多重集合   <set>           可逆容器、关联容器

  map   映射     <map>         可逆容器、关联容器

  multimap 多重映射       <map>         可逆容器、关联容器

设S表示一种容器类型(如:vector<int>),s1、s2都是S类型的实例,容器都具有如下基本功能

  S s1  容器的默认构造函数,用于构造一个没有任何元素的空容器。

  s1 op s2  对两容器之间的元素按字典序进行比较,op表示==、!=、<、<=、>、>=任何一个。

  s1.begin()  返回指向s1第一个元素的迭代器

  s1.end()  返回指向s1最后一个元素的下一个位置的迭代器。

  s1.empty()  表示s1容器是否为空,返回一个布尔值。

  s1.size()  返回s1容器中元素的个数。

  s1.swap(s2)  将s1容器和s2容器的内容交换。

与类型为S的容器相关联的迭代器的类型

S::iterator  (与S相关的普通迭代器类型,迭代器指向的元素类型为T)

S::const_iterator  (表示与S相关的常迭代器类型,迭代器指向的元素类型为const T,通过这样的迭代器只能读取元素,不能改写元素

按照容器中元素的组织方式,容器可分为: “顺序容器”(相同类型元素以严格线性形式组织)  和  “关联容器”(可根据一组索引快速提取元素)。

按照与容器所关联的迭代器类型,又有“可逆容器”这一概念。可逆容器又有“随机访问容器”的子概念。

每一个可逆容器都有逆向迭代器

s1.rbegin()  返回指向容器最后一个元素的逆向迭代器。

s1.rend()  返回容器的第一个元素的前一个位置的逆向迭代器。

逆向迭代器的类型:S::reverse_iterator  和 S::const_reverse_iterator

逆向迭代器的“++”运算 被映射为普通迭代器的“--”,“--”运算 被映射为普通迭代器的“++”。

一个迭代器和它的逆向迭代器可以相互转换

逆向迭代器类型都有一个构造函数,用来构造一个迭代器的逆向迭代器:

  如p1是S::iterator迭代器,那么S::reverse_iterator(p1)将得到p1的逆向迭代器

逆向迭代器有一个成员函数base,用来得到构造了此逆向迭代器的那个迭代器。

  如r1是通过S::reverse_iterator(p1)构造的迭代器,那么,r1.base()==p1.

r1.begin()、r1.end()、r1.rbegin()、r1.rend()之间的关系:

  s1.rbegin()==S::reverse_iterator(s1.end()),    s1.rbegin().base()==s1.end();

  s1.rend()==S::reverse_iterator(s1.begin()),    s1.rend().base==s1.begin()

随机访问容器提供的迭代器是“随机访问迭代器”,它可以直接通过一个整数来访问容器中的指定元素。

STL容器基本功能与分类的更多相关文章

  1. Sword STL容器分类介绍

    标准STL序列容器:vector.string.deque和list. 标准STL关联容器:set.multiset.map和multimap. 非标准序列容器slist和rope.slist是一个单 ...

  2. STL容器的适用情况

     转自http://hsw625728.blog.163.com/blog/static/3957072820091116114655254/ ly; mso-default-props:yes; m ...

  3. 关于STL容器

    容器: 概念:如果把数据看做物体,容器就是放置这些物体的器物,因为其内部结构不同,数据摆放的方式不同,取用的方式也不同,我们把他们抽象成不同的模板类,使用时去实例化它 分类: 序列容器.关联容器.容器 ...

  4. STL 容器的概念

    STL 容器的概念 在实际的开发过程中,数据结构本身的重要性不会逊于操作于数据结构的算法的重要性,当程序中存在着对时间要求很高的部分时,数据结构的选择就显得更加重要. 经典的数据结构数量有限,但是我们 ...

  5. C++中STL容器的比较

    基本参考 https://blog.csdn.net/qq_14898543/article/details/51381642 容器特性: vector:典型的序列容器,C++标准严格要求次容器的实现 ...

  6. STL容器的本质

    http://blog.sina.com.cn/s/blog_4d3a41f40100eof0.html 最近在学习unordered_map里面的散列函数和相等函数怎么写.学习过程中看到了一个好帖子 ...

  7. C++ STL 容器之栈的使用

    Stack 栈是种先进后出的容器,C++中使用STL容器Stack<T> 完美封装了栈的常用功能. 下面来个demo 学习下使用栈的使用. //引入IO流头文件 #include<i ...

  8. C++ STL容器总结

    1.    STL 容器 1.    按种类划分 顺序容器( sequence containers):是一种各元素之间有顺序关系的线性表,是一种线性结构的可序群集.顺序性容器中的每个元素均有固定的位 ...

  9. STL容器底层数据结构的实现

    C++ STL 的实现: 1.vector      底层数据结构为数组 ,支持快速随机访问   2.list            底层数据结构为双向链表,支持快速增删   3.deque     ...

随机推荐

  1. 当给属性添加final 时候 则无法进行第二次值的修改

  2. 【BZOJ 3652】大新闻 数位dp+期望概率dp

    并不难,只是和期望概率dp结合了一下.稍作推断就可以发现加密与不加密是两个互相独立的问题,这个时候我们分开算就好了.对于加密,我们按位统计和就好了;对于不加密,我们先假设所有数都找到了他能找到的最好的 ...

  3. C++中三种传递参数方法的效率分析

    众所周知,在C++中有三种参数传递的方式: 按值传递(pass by value) #include <iostream> using namespace std; void swap(i ...

  4. 文件查找 locate 和 find

    locate locate命令依赖于一个数据库文件,系统默认每天会检索一次系统中的所有文件,然后将检索到的文件记录到数据库中; 在执行查找时,可直接到数据库中查找记录,所以locate比find反馈更 ...

  5. Redis学习基础三

    回顾: 上一基础上浅尝了redis的存储数据类型,这一节将分别介绍数据类型的基础使用 一.启动本地Redis服务 1.打开cmd 窗口 使用 cd 命令切换至redis 安装根目录 运行: redis ...

  6. Educational Codeforces Round 26 D dp

    D. Round Subset time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...

  7. git<git rebase 修改以前提交过的内容>

      git rebase 使用总结: 使用git rebase 修改以前已经提交的内容 比如要修改之前的commit的 hashcode为:187f869c9d54c9297d6b0b1b4ff47d ...

  8. python抓取

    我要抓取奥巴马每周的演讲内容http://www.putclub.com/html/radio/VOA/presidentspeech/index.html 如果手动提取,就需要一个个点进去,再复制保 ...

  9. Eclipse开发java程序里Test用不了,怎么导包?

    1.右键项目Build Path->Add External JARs,选择要导入的jar包即可: 2.建立方法,引入junit. 3.ok

  10. Kubernetes集群中Service的滚动更新

    Kubernetes集群中Service的滚动更新 二月 9, 2017 0 条评论 在移动互联网时代,消费者的消费行为已经“全天候化”,为此,商家的业务系统也要保持7×24小时不间断地提供服务以满足 ...