标签:c++ 程序员 面试 map unordered_map
STL中map的底层为红黑树,所以查找的时间复杂度为O(logn)。
unordered_map是根据哈希值(遇到哈希值相同时用==号比较)寻找键,所以时间复杂度为O(1)。
键类型为自定义类型时,map需要重载键类型的<符号,unordered_map需要定义键类型的哈希函数(在类外定义),以及重载键类型的==符号。
class person1 { public: string name; int age; person1(string s,int i):name(s),age(i){} //map必须重载键类型的<符号 const bool operator<(const person1 &a)const { if(age!=a.age) return age<a.age; else return name<a.name; } }; class person2 { public: string name; int age; person2(string s,int i):name(s),age(i){} //unordered_map必须重载键类型的==符号,才能在哈希值相等的情况下找到准确的键值对 const bool operator==(const person2 &a)const { return age==a.age && name==a.name; } }; //person2类的哈希函数 struct person2_hash { //unordered_map必须定义键类型的哈希函数 size_t operator()(const person2 &p)const { return hash<int>()(p.age)+hash<char>()(p.name[0]); } }; //测试代码 //map操作 map<person1,string> map_person; person1 p1("Tom",15); person1 p2("Tim",22); //map_person.emplace("Tim",22,"driver"); 该行语法错误 map_person[p1]="student"; map_person[p2]="driver"; cout<<map_person[p1]<<endl;//输出 student cout<<map_person[p2]<<endl;//输出 driver //unordered_map操作 unordered_map<person2,string,person2_hash> unordered_person; person2 x1("Ton",14);//x1和x2的哈希值相等 person2 x2("Tim",14); person2 x3("John",50); unordered_person[x1]="I am Ton"; unordered_person[x2]="I am Tim"; unordered_person[x3]="I am John"; cout<<unordered_person[x1]<<endl;//输出 I am Ton cout<<unordered_person[x2]<<endl;//输出 I am Tim cout<<unordered_person[x3]<<endl;//输出 I am John
【map】【unordered_map】map和unordered_map中键类型为自定义类型的操作
标签:c++ 程序员 面试 map unordered_map
原文地址:http://blog.csdn.net/bupt8846/article/details/42774853