stl关联式容器的接口和实现】的更多相关文章

一.关联式容器 标准的STL关联式容器分为set(集合)/map(映射表)两大类,以及这两大类的衍生体multiset(多键集合)和 multimap(多键映射表).这些容器的底层机制均以RB-tree(红黑树)完成.RB-tree也是一个独立容器,但并不开放给外界使用. 此外,SGI STL 还提供了一个不在标准规格之列的关联式容器:hash table (散列表),以及以此hash table 为底层机制而完成的hash_set(散列集合).hash_map(散列映射表).hash_mult…
引入 继上文 STL序列式容器使用注意.概念总结 继续总结关联式容器的概念以及一些使用事项. 关联式容器与容器适配器 基础容器 STL 中的关联式底层容器:RB tree, hash table,可以作为其他容器的底层结构. 1.RB tree RB tree 红黑树这玩意儿可是重量级的,书中从基本的树概念讲起,到二叉树.BST.AVL,然后才到 RB tree.简单来说,AVL 是高度极其平衡的 BST,任意节点的左右子树高度差不超过 1 .那为什么还要 RB tree 呢?因为实践证明 AV…
关联式容器(associative containers) 根据数据在容器中的排列特性,容器可分为序列式(sequence)和关联式(associative)两种. 标准的STL关联式容器分为set(集合)和map(映射表)两大类,以及两大类的衍生体multiset(多键集合)和multimap(多键映射表).这些容器的底层机制均是以RB-tree(红黑树)完成.RB-tree也是一个独立的容器,但并不开放给外界使用. 此外,SGI STL还提供一个不在规格标准之列的关联式容器:hash tab…
1.关联式容器的概念 上一篇文章讲序列式容器,序列式容器的概念与关联式容器相对,不提供按序索引.它分为set和map两大类,这两大类各自有各自的衍生体multiset和multimap,的底层机制都是用红黑树实现,红黑树是一种基本平衡的二叉搜索树,红黑树的原理wiki上讲得很清楚,书中只是把算法实现在了底层而已,在SGI STL中RB-tree是作为底层数据结构供其他容器配接用,因此关联容器可以看做都是adaptor模式的应用. 关联式容器的概念类似于关联式数据库,为获得良好的搜索效率,一般用平…
关联式容器依据特定的排序准则,自动为其元素排序.缺省情况下以operator<进行比较.set multiset map multimap是一种非线性的树结构,具体的说是采用一种比较高效的特殊平衡检索二叉树--红黑树结构. 1.set set和multiset会根据特定的排序准则,自动将元素排序.两者的不同处在于multiset允许元素重复,而set不允许. template<class _Kty, class _Pr = less<_Kty>, class _Alloc = al…
什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象,当然这是一个朴素的理解,这种“对象”还包含了一系列处理“其它对象”的方法,因为这些方法在程序的设计上会经常被用到,所以容器也体现了一个好处,就是“容器类是一种对特定代码重用问题的良好的解决方案”. 容器还有另一个特点是容器可以自行扩展.在解决问题时我们常常不知道我们需要存储多少个对象,也就是说我们…
关联式容器的特征:所用元素都会根据元素的键值自动被排序. set STL 中的关联式容器低层数据结构为红黑树,其功能都是调用低层数据结构中提供的相应接口. set元的元素不会像map那样同时拥有键(key)和值(value). set元素的键就是值,值就是键,并不允许两个元素有相同的键. multiset允许相同键值存在. 因为set元素的键和值相等,所以不允许对set元素的值进行修改.(数据结构会根据key对元素进行排序,对value的更改会改变树中元素的排列顺序). set容器提供的迭代器为…
引入 最近看了<STL源码剖析>的第 4 章和第 5 章,介绍了 C++ STL 中的序列式容器和关联式容器,本文将总结序列式容器的基础概念,不会详细它们的实现原理(想知道自个儿看书吧,我目前只想了解它们的基本原理,用的时候心里有数就行). 容器概念 容器是存储数据的地方.C++ STL 容器是一些常见数据结构的实现.任何数据结构都是为了特定的算法服务的. 数据结构:数据的特定排列方式. 根据数据在容器中的排列方式,将容器分为序列式容器和关联式容器. 接下来将介绍序列式容器:array, ve…
stl中set和map为关联式容器,会根据排序准将元素自动排序.原型如下: template<class _Kty, class _Pr = less<_Kty>, class _Alloc = allocator<_Kty> > class set template<class _Kty, class _Ty, class _Pr = less<_Kty>, class _Alloc = allocator<pair<const _Kty…
map是一类关联式容器,自动建立Key - Value的对应 , key 和 Value可以是任意你需要的类型.下面介绍 map 中一些常用的函数: 一.map 中的 begin 和 end 函数 map<char , int> m ; m['a'] = 100 ; m['b'] = 200 ; m['c'] = 300 ; m.begin() -> first;      // 输出第一个元素的键值 m.begin() -> second ;    // 输出第一个元素的 val…