STL学习笔记
简介
STL(Standard Template Library),即标准模版库,涵盖了常用的数据结构和算法,并具有跨平台的特点。STL是C++标准函数库的一部分,如下图所示:

STL含有容器、算法和迭代器组件,其之间的合作如下图所示:

STL的底层机制都是以RB-tree(红黑树)完成的。一个红黑树是一棵二叉树。
容器
标准序列式容器
字符串(string)
std::string不能初始化为NULL。
向量(vector)
向量(vector) 连续存储的元素。
vector和数组类似,拥有一段连续的内存空间,且起始地址不变,因此能非常好的支持随机存储。
为了提高效率,vector在添加元素之前最好调用reserve()设置容量。
(1)清空
std::vector<std::string> str; std::vector<std::string>().swap(str);
str.clear();
(2)删除符合条件的元素
vector<int> iVec; vector<int>::iterator it;
for(it=iVec.begin();it!=iVec.end();)
{
if(*it == )
{
it=iVec.erase(it);//删除元素,返回值指向已删除元素的下一个位置
}
else
{
++it;//指向下一个位置
}
}
注意:每次调用erase()函数后,被删除之后的内容会自动往前移。
(3)使用sort排序,需要头文件#include<algorithm>
sort(vec.begin(),vec.end());//默认是按升序排列,即从小到大
可以通过重写排序比较函数按照降序比较,定义排序比较函数如下:
bool Comp(const int &a,const int &b)
{
return a>b;
}
按如下方式调用即可实现降序排序:
sort(vec.begin(),vec.end(),Comp)
列表(list)
列表(list) 由节点组成的双向链表,每个结点包含着一个元素。
list是由数据结构中的双向链表实现的,其内存空间可以是不连续的,只能通过指针来进行数据的访问。由于链表的特点,其可以以很好的效率支持任意地方的删除和插入。
双端队列(deque)
双端队列(deque) 连续存储的指向不同元素的指针所组成的数组。
deque是由一段一段定量的连续空间组成的,是动态数组类型。
容器适配器
栈(stack)
栈(stack) 后进先出的值的排列。
队列(queue)
队列(queue) 先进先出的值的排列。
优先队列(priority_queue)
优先队列(priority_queue) 元素的次序是由作用于所存储的值对上的某种谓词决定的的一种队列。
标准关联式容器
关联容器的内部结构是一个平衡二叉树(balanced binary tree)。平衡二叉树有如下几种:
- AVL-tree
- RB-tree
- AA-tree
集合(set)
集合(set) 由节点组成的红黑树,每个节点都包含着一个元素,节点之间以某种作用于元素对的谓词排列,没有两个不同的元素能够拥有相同的次序。
多重集合(multiset)
多重集合(multiset) 允许存在两个次序相等的元素的集合。
映射(map)
映射(map) 由{键,值}对组成的集合,以某种作用于键对上的谓词排列。map底层是红黑树RB-tree。
(1)按键排序
为了实现快速查找,map内部本身就是按序存储的(比如红黑树)。在我们插入<key, value>键值对时,就会按照key的大小顺序进行存储。默认排序是按照从小到大。
//按键排序,默认排序是按照从小到大
std::map<int,std::string> mapScore;
mapScore.insert(std::make_pair(,"sun"));
mapScore.insert(std::make_pair(,"gao"));
mapScore.insert(std::make_pair(,"zhao"));
mapScore.insert(std::make_pair(,"yuan"));
(2)按值排序
//按值排序
struct CmpByValue {
bool operator()(const std::pair<std::string,int> & lhs, const std::pair<std::string,int> & rhs)
{return lhs.second > rhs.second;}
};
std::map<std::string, int> mapScore;
mapScore["LiMin"] = ;
mapScore["ZiLinMi"] = ;
mapScore["BoB"] = ;
mapScore.insert(std::make_pair("Bing",));
mapScore.insert(std::make_pair("Albert",));
//把map中元素转存到vector中
std::vector<std::pair<std::string, int>> vecMapScore(mapScore.begin(), mapScore.end());
sort(vecMapScore.begin(), vecMapScore.end(), CmpByValue());
参考链接:http://blog.csdn.net/iicy266/article/details/11906189?utm_source=tuicool&utm_medium=referral
多重映射(multimap)
多重映射(multimap) 允许键对有相等的次序的映射。
非标准关联式容器
hashmap、hashset、hashtable,底层是哈希表。
迭代器
算法
STL学习笔记的更多相关文章
- Effective STL 学习笔记 39 ~ 41
Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value
Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value */--> div.org-src-container ...
- Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据
Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...
- Effective STL 学习笔记 32 ~ 33
Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 31:排序算法
Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 Item 30: 保证目标区间足够大
Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...
- Effective STL 学习笔记 Item 26: Prefer Iterator to reverse_iterator and const_rever_itertor
Effective STL 学习笔记 Item 26: Prefer Iterator to reverse_iterator and const_rever_itertor */--> div ...
- Effective STL 学习笔记: Item 22 ~ 24
Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...
- Effective STL 学习笔记 Item 21:Comparison Function 相关
Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...
- Effective STL 学习笔记:19 ~ 20
Effective STL 学习笔记:19 ~ 20 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
随机推荐
- IT界里的生日
MS-DOS 1981年7月27日 windows 3.0 1990年5月22日 windows 3.11 1992年3月18日 Windows 95 1995年8月24日 Windows ...
- [转载]jquery中attr和prop的区别
在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这些问题就出现了. 关于它们两个的区别,网上的答案很多.这里谈谈我的心得,我的心得很简单: ...
- 修改tomcat应用日志默认编码格式
前言 今天开发跟我说tomcat日志中的中文不能正常显示,根据以往的经验,我觉得可能跟服务器的编码有关,于是尝试各种方法,但还是没能解决问题. 后来我突然想到会不会跟tomcat的设置有关呢,于是在网 ...
- 深入jQuery中的Callbacks()
引入 初看Callbacks函数很不起眼,但仔细一瞅,发现Callbacks函数是构建jQuery大厦的无比重要的一个基石.jQuery中几乎所有有关异步的操作都会用到Callbacks函数. 为什么 ...
- 机器学习PR:k近邻法分类
k近邻法是一种基本分类与回归方法.本章只讨论k近邻分类,回归方法将在随后专题中进行. 它可以进行多类分类,分类时根据在样本集合中其k个最近邻点的类别,通过多数表决等方式进行预测,因此不具有显式的学习过 ...
- jsPlumb的简单使用
jsPlumb概述jsPlumb是一个在dom元素之间绘制连接线的javascript框架,它使用svg技术绘制连接线. 基本概念很明显,一个连线主要要解决的问题包括谁和谁连,在哪里连(连接点在哪里) ...
- C语言 值传递和地址传递
不少同学在学到C语言的指针部分时感到很困惑,对经常提到的"值传递"和"地址传递"两个概念弄不 明白.实际上,因为地址本身也可以作为一个特殊的"值&qu ...
- Spring+springmvc+Mybatis整合案例 xml配置版(myeclipse)详细版
Spring+springmvc+Mybatis整合案例 Version:xml版(myeclipse) 文档结构图: 从底层开始做起: 01.配置web.xml文件 <?xml version ...
- latex学习--基础知识
1 文档结构 文档类.序言.正文 这三部分的基本语法如下: 文档类常用选项 标题.摘要.章节 目录 2 文字排版 字符输入 换行.换页.断字 字样.字号 3 常用命令环境 列表 对齐 摘录 原文照排 ...
- Redis(二) 扩展
事务multi ... exec 之间的操作先进入等待队列,到exec时一起执行 事物的所有操作结果都是一起返回的,所以前一条指令的结果无法作为后一条指令的参数 ...