STL容器基本功能与分类
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容器基本功能与分类的更多相关文章
- Sword STL容器分类介绍
标准STL序列容器:vector.string.deque和list. 标准STL关联容器:set.multiset.map和multimap. 非标准序列容器slist和rope.slist是一个单 ...
- STL容器的适用情况
转自http://hsw625728.blog.163.com/blog/static/3957072820091116114655254/ ly; mso-default-props:yes; m ...
- 关于STL容器
容器: 概念:如果把数据看做物体,容器就是放置这些物体的器物,因为其内部结构不同,数据摆放的方式不同,取用的方式也不同,我们把他们抽象成不同的模板类,使用时去实例化它 分类: 序列容器.关联容器.容器 ...
- STL 容器的概念
STL 容器的概念 在实际的开发过程中,数据结构本身的重要性不会逊于操作于数据结构的算法的重要性,当程序中存在着对时间要求很高的部分时,数据结构的选择就显得更加重要. 经典的数据结构数量有限,但是我们 ...
- C++中STL容器的比较
基本参考 https://blog.csdn.net/qq_14898543/article/details/51381642 容器特性: vector:典型的序列容器,C++标准严格要求次容器的实现 ...
- STL容器的本质
http://blog.sina.com.cn/s/blog_4d3a41f40100eof0.html 最近在学习unordered_map里面的散列函数和相等函数怎么写.学习过程中看到了一个好帖子 ...
- C++ STL 容器之栈的使用
Stack 栈是种先进后出的容器,C++中使用STL容器Stack<T> 完美封装了栈的常用功能. 下面来个demo 学习下使用栈的使用. //引入IO流头文件 #include<i ...
- C++ STL容器总结
1. STL 容器 1. 按种类划分 顺序容器( sequence containers):是一种各元素之间有顺序关系的线性表,是一种线性结构的可序群集.顺序性容器中的每个元素均有固定的位 ...
- STL容器底层数据结构的实现
C++ STL 的实现: 1.vector 底层数据结构为数组 ,支持快速随机访问 2.list 底层数据结构为双向链表,支持快速增删 3.deque ...
随机推荐
- Cent7安装mysql5.7.11全过程
下载mysql(注:其他版本未测试) https://cdn.mysql.com/archives/mysql-5.7/mysql-boost-5.7.11.tar.gz 1.安装依赖包 yum -y ...
- POJ3281_Dining
有一些饮料和食物,每种一个,每个客人喜欢一些饮料和一些食物,每个客人可以选择一种饮料和一种食物,问最多能够同时满足多少个客人同时拥有饮料和食物. 这样的,源点连接饮料,汇点连接食物,中间人分别连接饮料 ...
- Python实现双色球和大乐透摇奖
实现代码: # code by kadycui # 模块引用 import random def select(): print('\n') print('请选择彩票种类') print('双色球输入 ...
- 【刷题】BZOJ 2346 [Baltic 2011]Lamp
Description 2255是一个傻X,他连自己家灯不亮了都不知道. 某天TZ大神路过他家,发现了这一情况, 于是TZ开始行侠仗义了. TZ发现是电路板的问题, 他打开了电路板,发现线路根本没有连 ...
- js 弹出新页面,避免被浏览器、ad拦截的一种办法
以绑定click弹窗的方式,改为普通的链接,即 a[target=_blank],在点击打开新窗口之前,修改其href. 绑定mousedown,鼠标点击执行完成前修改href. 绑定focus,保证 ...
- MYSQL指定用户访问指定数据库
1.使用navicat 1)首先使用root用户新建连接 2)新建mysql用户 3)点击权限,选择添加权限,出现MySQL中已存在的数据库列表,选择你要为该新建用户开放的数据库,此处选择“maiba ...
- mysql 中的共享锁和排他锁
共享锁(share lock) 共享锁又称读锁,是读取操作创建的锁.其他用户可以并发读取数据,但任何事务都不能对数据进行修改(获取数据上的排他锁),直到已释放所有共享锁. 如果事务T对数据A加上共享锁 ...
- [python]python安装包错误
“UnicodeDecodeError: ‘ascii’ codec can’t decode : ordinal not )” 在windows XP上 解决方法: Solution: ====== ...
- 【Asp.net入门01】动态网站基础知识
本节将介绍: 网站搭建流程 动态网站相关基础概念 网页的访问原理 使用浏览器访问网站是我们几乎天天在做的事情.以前我们只需要关注网页内容,作为网站开发人员,从现在开始我们要关注更深层次的东西了. 1. ...
- MySQL内存计算器
MySQL如何使用内存? 首先,介绍MySQL使用内存的一些方法: 1. 会话级别的内存消耗(连接私有内存):如sort_buffer_size等,每个会话都会开辟一个sort_buffer_size ...