在刷算法题的时候老是碰到好多题,号称能够用hash table来解题。而后就蒙圈了。算法
1.首先,map和hash_map的区别和使用:函数
(1)map底层用红黑树实现,hash_map底层用hash_table 实现。因此map的时间复杂度为O(logn), hash_map为O(1)。spa
(2)map和hash_map都在stl中,直接include,可是在Mac系统中要#include <ext/hash_map>和 using namespace __gnu_cxx;code
(3)以map为例来讲明使用(hash_map的使用方法和map同样的):对象
a. 定义: map<int, string> person;blog
b. 插入:person[1000] = "Rambo"; //直接插入,开销很大,先查找key为1000的value再插入Rambostring
person.insert(map<int, string>::value_type(1000, "Rambo")); //开销较小hash
c. 查找:使用find()和count()函数it
find()传入参数key,返回iterator,若是找不到,返回为end()。iterator数据类型为std::pair对象,iterator->first表示key,table
iterator->second表示value。
int key = 123; map<int, string>::iterator it = person.find(key); if(it == person.end()) //没找到 else //找到了
d.删除元素: person.erase(iterator it), person.erase(const Key& key); person.clear();
2.hash table:
3.红黑树:
这两部份内容比较复杂,有空再弄吧。