boost unordered 初识
2014-04-26 17:45
302 查看
boost中的unordered_set/unordered_map/unordered_multiset/unordered_multimap都类似,以下统称unordered。
unordered中所使用的散列方法是除法散列法。
散列函数是 h(k) = k mod m。
其中k是元素的哈希值,m是unordered中桶的个数。为了尽量避免散列冲突,桶的个数m应该取素数。
元素存放方式是哈希桶(以下简称桶),即每个具有相同散列值h(k)的元素存放在同一个桶中。
举个例子:
上图中 m = 7,即有7个桶。
h(E) = 0,所以元素E被放在第1个桶中,
由于h(A) = h(D),所以元素A和D被放在同一个桶中。
unordered中所使用的散列方法是除法散列法。
散列函数是 h(k) = k mod m。
其中k是元素的哈希值,m是unordered中桶的个数。为了尽量避免散列冲突,桶的个数m应该取素数。
元素存放方式是哈希桶(以下简称桶),即每个具有相同散列值h(k)的元素存放在同一个桶中。
举个例子:
上图中 m = 7,即有7个桶。
h(E) = 0,所以元素E被放在第1个桶中,
由于h(A) = h(D),所以元素A和D被放在同一个桶中。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Python中map()函数浅析
- 关于指针的一些事情
- Android使用Google Map浅谈
- boost相关小知识(长期顶置更新)
- C/C++数据对齐详细解析
- C++中引用的使用总结
- C与C++之间相互调用实例方法讲解
- C++中引用(&)的用法与应用实例分析
- 解析C++ 浮点数的格式化输出
- 深入分析C++中几个最不常用的关键字
- c++中inline的用法分析
- C++ Primer 第一部分基本语言
- 深入解析C++ Data Member内存布局
- 从汇编看c++中默认构造函数的使用分析
- 关于C++中的友元函数的一些总结
- C++的sstream标准库详细介绍
- 基于C++自动化编译工具的使用详解
- 浅谈C++中的string 类型占几个字节
- C/C++ 宏详细解析