map
(map)是一棵红黑树,它作为一个容器储存的是一个键值对另一个关键码的映射。必须要定义键值类型的小于号。
声明方法是:map<a,b> name;
其中(a)和(b)是数据类型,(name)是这棵红黑树的名字。
一般(map)都可以当做(hash)表来用,但是因为(map)内部是靠平衡树维护的,所以复杂度是(O(log))的,比一般的手写(hash)要慢。但是(map)还支持中括号操作,所以一般情况下十分方便写。
声明方式
map<char,int> s;
map<char,int>::iterator it;
假设类型(a)是(char),类型(b)是(int),那么定义一个(map)和这个(map)的迭代器就是这样写。迭代器只支持访问连续地址,所以就只能(++it)和(--it)。如果我用这个(map)来统计每个字符出现的次数,那么就可以直接写s[ch]++;
name.size()
返回元素个数。
name.empty()
判断(map)是否为空,为空则是逻辑真,否则就是逻辑假。
name.clear()
清空(map)。
name.begin()/name.end()
返回(map)的首迭代器和尾迭代器。左闭右开,所以尾迭代器为空。
对迭代器解除引用后会得到一个(pair)。
name.insert(pair<a,b>)/name.erase(pair<a,b>(或迭代器))
插入一个(pair)类型,删除一个(pair)或者是迭代器。
name.find(x)
返回一个迭代器,存的是一个第一关键字为(x)的二元组。若不存在,则返回(name.end())。
[]操作符
s[x]可以直接访问第一关键字与x相等的二元组的第二关键字。但是如果不存在(map)就会先新建一个二元组,使得这个新建的二元组第一关键字为x,第二关键字为(0)。所以在使用[]操作符之前最好先(find)一下以x为第一关键字的二元组是否存在,不然用多了就会出现大量的无用二元组。