unordered_map 与 map 的区别和联系
2017-07-17 21:31
204 查看
unordered_map和map类似,都是存储的key-value的值,可以通过key快速索引到value。不同的是unordered_map不会根据key的大小进行排序,
存储时是根据key的hash值判断元素是否相同,即unordered_map内部元素是无序的,而map中的元素是按照二叉搜索树存储,进行中序遍历会得到有序遍历。
所以使用时map的key需要定义operator<。而unordered_map需要定义hash_value函数并且重载operator==。但是很多系统内置的数据类型都自带这些,
那么如果是自定义类型,那么就需要自己重载operator<或者hash_value()了。
结论:如果需要内部元素自动排序,使用map,不需要排序使用unordered_map
输出为:(根据age进行了排序的结果)
Tom1 20
Tom3 22
Tom4 23
Tom5 24
因为Tom2和Tom3的age相同,由我们定义的operator<只是比较的age,所以Tom3覆盖了Tom2,结果中没有Tom2。
如果运算符<的重载是如下:
对于hash_value的重载没有成功,在vs2013上报错。
存储时是根据key的hash值判断元素是否相同,即unordered_map内部元素是无序的,而map中的元素是按照二叉搜索树存储,进行中序遍历会得到有序遍历。
所以使用时map的key需要定义operator<。而unordered_map需要定义hash_value函数并且重载operator==。但是很多系统内置的数据类型都自带这些,
那么如果是自定义类型,那么就需要自己重载operator<或者hash_value()了。
结论:如果需要内部元素自动排序,使用map,不需要排序使用unordered_map
// map的使用 #include<string> #include<iostream> #include<map> using namespace std; struct person { string name; int age; person(string name, int age) { this->name = name; this->age = age; } bool operator < (const person& p) const { return this->age < p.age; } }; map<person,int> m; int main() { person p1("Tom1",20); person p2("Tom2",22); person p3("Tom3",22); person p4("Tom4",23); person p5("Tom5",24); m.insert(make_pair(p3, 100)); m.insert(make_pair(p4, 100)); m.insert(make_pair(p5, 100)); m.insert(make_pair(p1, 100)); m.insert(make_pair(p2, 100)); for(map<person, int>::iterator iter = m.begin(); iter != m.end(); iter++) { cout<<iter->first.name<<"\t"<<iter->first.age<<endl; } return 0; }
输出为:(根据age进行了排序的结果)
Tom1 20
Tom3 22
Tom4 23
Tom5 24
因为Tom2和Tom3的age相同,由我们定义的operator<只是比较的age,所以Tom3覆盖了Tom2,结果中没有Tom2。
如果运算符<的重载是如下:
bool operator < (const person &p)const{ return this->name < p.name; }
输出结果: 按照 那么进行的排序,如果有那么相同则原来的那么会被覆盖 Tom1 20 Tom2 22 Tom3 22 Tom4 23 Tom5 24
// unordered_map的使用: #include<string> #include<iostream> #include<unordered_map> using namespace std; struct person { string name; int age; person(string name, int age) { this->name = name; this->age = age; } bool operator== (const person& p) const { return name==p.name && age==p.age; } }; size_t hash_value(const person& p) { size_t seed = 0; std::hash_combine(seed, std::hash_value(p.name)); std::hash_combine(seed, std::hash_value(p.age)); return seed; } int main() { typedef std::unordered_map<person,int> umap; umap m; person p1("Tom1",20); person p2("Tom2",22); person p3("Tom3",22); person p4("Tom4",23); person p5("Tom5",24); m.insert(umap::value_type(p3, 100)); m.insert(umap::value_type(p4, 100)); m.insert(umap::value_type(p5, 100)); m.insert(umap::value_type(p1, 100)); m.insert(umap::value_type(p2, 100)); for(umap::iterator iter = m.begin(); iter != m.end(); iter++) { cout<<iter->first.name<<"\t"<<iter->first.age<<endl; } return 0; }
对于hash_value的重载没有成功,在vs2013上报错。
相关文章推荐
- map与unordered_map的区别与联系
- C++中map,hash_map,unordered_map,unordered_set区别与联系
- set/multiset map/multimap hash_set/hash_multiset hash_map/hash_multimap 区别与联系
- set,list,map区别与联系
- c++中map与unordered_map的区别
- std::map, std::multimap, std::tr1::unordered_map 区别
- std::map, std::multimap, std::tr1::unordered_map 区别 - 笔记本 - 博客频道 - CSDN.NET
- java 集合类Array、List、Map区别和联系
- set/multiset map/multimap hash_set/hash_multiset hash_map/hash_multimap 区别与联系
- List、Set、Collection、Map的区别和联系
- STL中list,vector,deque,map,set区别、联系和使用场景
- Java基本概念:集合类 List/Set/Map... 的区别和联系
- Java基本概念:集合类 List/Set/Map... 的区别和联系
- java 集合类Array、List、Map区别和联系
- HashTable,HashMap,LIST,SET,MAP的区别和联系
- hash与map的区别联系应用
- java 集合类Array、List、Map区别和联系
- java 集合类Array、List、Map区别和联系
- Java集合类List/Set/Map的区别和联系
- 辛星浅析array_walk()和array_map()的联系和区别