STL的关联式容器总结

作者: cpp加油站 | 来源:发表于2018-08-01 11:50 被阅读0次

1. map

1.1 map的底层实现

map是红黑树(一种非严格意义上的平衡二叉树),置于红黑树的具体可以看算法和数据结构,这里不多说。

1.2 map的元素类型

map的key类型必须要重载"<"操作符,无法重载时用自定义仿函数代替map的第三个参数,因为map是有序的。
map第一个参数是key,第二个参数是value,第三个参数是compare函数,第四个参数是内存配置对象
insert(std::pair<key,value>(1,'gg'))
判断insert是否成功:
pair<map<int,string>iterator, bool> insert_pair;
insert_pair = map.insert(std::pair<key,value>(1,'gg'));
if ( insert_pair.second == true )
cout << "success" << endl;
else
cout << "failed" << endl;

1.3 map遍历删除

map<int,string>::iterator iter = m.begin();
for(; iter != m.end();)
{
if ( iter->first % 10 == 0 )
{
m.erase(iter++); //不能直接在for里面自加,因为erase以后iter会失效
}
}

2. set

2.1 set的底层原理

set类似于数学里面的集合,不过set的集合中不包含重复的元素,这是和vector的第一个区别,第二个区别是set内部用红黑树实现,便于元素查找。在set中查找是使用二分查找法,所以set在查询方面速度很快。在set中做插入和删除效率也是比较高的,因为不需要做内存拷贝和内存移动。

3. 怎么判断该用什么容器

  • 如果需要高效的随机存取,不在乎插入和删除的效率,使用vector;
  • 如果需要大量的插入和删除元素,不关心随机存取的效率,使用list;
  • 如果需要随机存取,并且关心两端数据的插入和删除效率,使用deque;
  • 如果打算存储数据字典,并且要求方便地根据key找到value,一对一的情况使用map,一对多的情况使用multimap;
  • 如果打算查找一个元素是否存在于某集合中,唯一存在的情况使用set,不唯一存在的情况使用multiset。

相关文章

  • STL的关联式容器总结

    1. map 1.1 map的底层实现 map是红黑树(一种非严格意义上的平衡二叉树),置于红黑树的具体可以看算法...

  • GeekBand C++第五周

    STL 对定义的通用容器分三类:顺序性容器、关联式容器和容器适配器。 标准STL顺序容器:vector、deque...

  • 音视频开发之旅(22) STL 之 容器

    目录 STL的六大部件介绍 容器分类 序列式容器介绍(vector、list、deque) 关联式容器 资料 收获...

  • STL 容器篇----关联式容器

    关联式容器依据特定的排序准则, 自动为元素排序。 排序准则以函数形式呈现, 用来比较value 或 key. 容器...

  • JNI基础 -- C++基础知识(容器)

    C++ 中有两种容器 1.序列式容器 2.关联式容器 这两种容器都在stl标准模板库中 序列式容器 序列式容器:元...

  • STL容器set基础使用

    STL容器之set 一、什么是set? set关联式容器。 set作为一个容器也是用来存储同一数据类型的数据类型,...

  • c++程序员面试宝典之STL库

    十八.STL库 主要包括三大组件:容器、算法、迭代器。 容器:序列式容器:vector、deque、list;关联...

  • STL 源码剖析

    GitHub参考STL"源码"剖析-重点知识总结C++STL自己总结 序列式容器 所谓序列式容器,其中的元素都可序...

  • STL容器

    STL容器迭代器 STL容器迭代器失效情况分析、总结[https://ivanzz1001.github.io/r...

  • STL关联容器map

    map特点 不允许有重复的key,根据key排序 map用法 insert方法几种用法: 插入一个元素 插入一个r...

网友评论

    本文标题:STL的关联式容器总结

    本文链接:https://www.haomeiwen.com/subject/blilvftx.html