STL 笔记(二) 关联容器 map、set、multimap 和 multimap
STL 关联容器简单介绍
关联容器即 key-value 键值对容器,依靠 key 来存储和读取元素。
在 STL 中,有四种关联容器,各自是:
- map 键值对 key-value 存储,key 不可反复,即一个 key 仅仅能相应一个 value, 相应头文件<map>
- multimap 键值对 key-value 存储,key 能够反复,即一个 key 能够相应多个 value, 相应头文件<map>
- set 仅仅有 key, key 不可反复,相应头文件<set>
- multiset 仅仅有 key, key 能够反复。相应头文件<set>
STL 关联容器特点
- STL 关联容器的底层数据结构是红黑树。故其增删查的时间复杂度都是 O(logn)
- map 默认依照 key 的升序进行插入,非基本数据类型要求重载 < 运算符
- map 重载了 [] 运算符,使的插入和查找很方便
- map 用 [] 运算符訪问元素时,假设不存在这个key。key会自己主动插入,value为初始化值
- map 的 key 对象使用之后就不要再改动,假设必须改动,须要删除后又一次插入
- multimap 的 key-value 是一对多,没有重载 [] 运算符
map 经常使用函数
#构造:
map c: #创建空映射,不包括不论什么元素
map c(op): #以 op 为排序准则,产生一个空的map
map c1(c2): #复制 c2 中的元素到 c1 中
map c(const value_type *first, const value_type* last): #复制 [first, last) 之间元素构成新映射
map c(const value_type *first, const value_type* last,op): #以 op 为排序准则。复制[first, last)之间元素构成新映射
multimap m: #创建空映射,不包括不论什么元素
multimap m(op): #以 op 为排序准则,产生一个空的 multimap
multimap m1(m2): #复制 m2 中的元素到 m1 中
multimap m(const value_type *first, const value_type* last): #复制 [first, last)之间元素构成新映射
multimap m(const value_type *first, const value_type* last,op): #以op为排序准则,复制 [first, last)之间元素构成新映射
#增删
iterator insert(const value_type& x): #插入元素 x
iterator insert(iterator it,const value_type& x): #在迭代指针 it 处插入元素x
void insert(const value_type *first,const value_type* last): #插入[first, last)之间元素
iterator erase(iterator it): #删除迭代指针it处元素
iterator erase(iterator first,iterator last): #删除[first, last)之间元素
size_type erase(const Key& key): #删除键值等于key的元素
#遍历
iterator begin(): #返回首元素的迭代器指针
iterator end(): #返回尾元素的迭代器指针
reverse_iterator rbegin(): #返回尾元素的逆向迭代器指针
reverse_iterator rend(): #返回首元素前一个位置的迭代器指针
reference operator[](const Key& k): #仅仅用在映射map 类中。重载[],并返回值的引用
#功能
int size() const: #返回容器元素个数
bool empty() const: #推断容器是否空。若返回true。表明容器已空
const_iterator find(const Key& key) const: #查找返回键值等于 key 的迭代器指针
int count(const Key& key) const: #返回键值等于 key 的元素的个数
const_iterator lower_bound(const Key& key): #返回键大于等于 key 的第一个迭代器指针
const_iterator upper_bound(const Key& key): #返回键大于 key 的第一个迭代器指针
pair<const_iterator,const_iterator> equal_range(const Key& key) const: #返回一对迭代器,使得[first, last)内元素等于key
set 经常使用函数
#构造
set c: #创建空集合,不包括不论什么元素
set c(op): #以 op 为排序准则。产生一个空的 set
set c1(c2): #复制 c2 中的元素到 c1 中
set c(const value_type *first, const value_type* last): #复制 [first, last) 之间元素构成新集合
set c(const value_type *first, const value_type* last,op): #以 op 为排序准则。复制 [first, last) 之间元素构成新集合
multiset m: #创建空集合,不包括不论什么元素
multiset m(op): #以 op 为排序准则,产生一个空的 set
multiset m1(m2): #复制 m2 中的元素到 m1 中
multiset m(const value_type *first, const value_type* last): #复制 [first, last) 之间元素构成新集合
multiset m(const value_type *first, const value_type* last,op): #以 op 为排序准则,复制 [first, last) 之间元素构成新集合
#增删
pair<iterator,bool> insert( x): #插入元素x
iterator insert(iterator it,x): #在迭代器it处插入元素x
void insert(const value_type *first,const value_type *last): #插入[first, last)之间元素
iterator erase(iterator it): #删除迭代器指针it处元素
iterator erase(iterator first,iterator last): #删除[first, last)之间元素
size_type erase(const Key& key): #删除元素值等于key的元素
#遍历
iterator begin(): #返回首元素的迭代器指针
iterator end(): #返回尾元素的迭代器指针
reverse_iterator rbegin(): #返回尾元素的逆向迭代器指针
reverse_iterator rend(): #返回首元素前一个位置的迭代器指针
#功能
int size() const: #返回容器元素个数
bool empty() const: #推断容器是否为空,若返回true,表明容器已空
const_iterator find(const Key& key) const: #查找返回元素值等于key的迭代器指针
int count(const Key& key) const: #返回容器中元素等于key的元素的个数
const_iterator lower_bound(const Key& key): #返回键大于等于 key 的第一个迭代器指针
const_iterator upper_bound(const Key& key): #返回键大于 key 的第一个迭代器指针
pair<const_iterator,const_iterator> equal_range(const Key& key) const: #返回一对迭代器,使得[first, last)内元素等于key
void swap(set& s): #交换集合元素
void swap(multiset& s): #交换多集合元素
map 小样例
#include <iostream>
#include <map>
using namespace std; class Cat {
public:
int age;
Cat(int age) {
this->age = age;
}
/* map 底层是红黑树,用作 key 的对象必须可排序, 需重载 < 运算符 */
bool operator <(const Cat &c) const {
return age < c.age;
}
}; int main() {
map<char, char> m;
m.insert(map<char, char>::value_type('a', 'a'));
m['b'] = 'b';
cout << "m['a'] is: " << m['a'] << ", "; // 用运算符[]訪问
map<char, char>::iterator it = m.find('b'); // 用迭代器訪问
cout << "m['b'] is: " << it->second << ", ";
cout << "m['c'] is: " << m['c'] << endl; // 用 []訪问要先推断是否存在,不存在则会被插入
m['c'] = 'c';
m['d'] = 'd';
for (map<char, char>::iterator it = m.begin(); it != m.end(); it++) {
cout << it->first << ":"; // `first` 是 key, 不可改动(const 修饰)
cout << (*it).second << ", "; // `second` 是value,能够改动
}
map<char, char>::iterator it_low, it_up;
it_low = m.lower_bound('c');
it_up = m.upper_bound('c');
cout << "\nlower_bound('c') is: " << it_low->first << endl;
cout << "upper_bound('c') is: " << it_up->first << endl;
pair<map<char, char>::iterator, map<char, char>::iterator> ret;
ret = m.equal_range('c');
cout << "equal_range('c'): " << ret.first->first << ", "<< ret.second->first << endl;
map<Cat, char> t;
Cat c(1);
t[c] = 'a';
c.age = 2; // key 对象改动后,无法再从 map 查到这个键值对
cout << "改动 key 对象后,再次查找这个 key 出现的次数: " << t.count(c) << endl;
} /* 输出:
m['a'] is: a, m['b'] is: b, m['c'] is:
a:a, b:b, c:c, d:d,
lower_bound('c') is: c
upper_bound('c') is: d
equal_range('c'): c, d
改动 key 对象后。再次查找这个 key 出现的次数: 0
*/
【地址:http://blog.csdn.net/thisinnocence/article/details/39646813】
STL 笔记(二) 关联容器 map、set、multimap 和 multimap的更多相关文章
- STL笔记(1)map
STL笔记(1)map STL之map ZZ from http://hi.baidu.com/liyanyang/blog/item/d5c87e1eb3ba06f41bd576cf.html 1. ...
- C++关联容器<map>简单总结
C++关联容器<map>简单总结 map提供大小可变的关联容器,基于关联键值高效检索元素值.当你处理键值对的数据是,都可以考虑使用map关联容器. 特点: 大小可变的关联容器,基于关联键值 ...
- c++中关联容器map的使用
C++关联容器<map>简单总结(转) 补充: 使用count,返回的是被查找元素的个数.如果有,返回1:否则,返回0.注意,map中不存在相同元素,所以返回值只能是1或0. 使用find ...
- STL学习笔记(三) 关联容器
条款19:理解相等(equality)和等价(equivalence)的区别 相等的概念是基于 operator== 的,如果 operator== 的实现不正确,会导致并不实际相等等价关系是以&qu ...
- C++ 之关联容器 map
标准库定义了四种关联容器:map是其中之一(另外还有set.multimap.multiset).map的元素以键-值(key-value),在学了顺序容器之后,再学习关联容器,就比较比较好理解了. ...
- 高放的c++学习笔记之关联容器
标准库提供8个关联容器 按关键字有序保存有(红黑树实现) set map multset 关键字可重复出现的set multimap 关键字可重复出现的map 无序保存 哈希实现 unorderre ...
- 关联容器——map、set
map类型通常被称为关联数组,与正常数组类似,不同之处在于其下标不必是整数.我们通过一个关键字而不是位置来查找值(键值对). 与之相对,set就是关键字的简单集合.当只是想知道一个值是否存在时,set ...
- 关联容器(map):支持高效查找的容器,一种键值对的集合。
#include <iostream> #include <string> #include <map> #include <vector> using ...
- 关联容器map(红黑树,key/value),以及所有的STL容器详解
字符串或串(String)是由数字.字母.下划线组成的一串字符.一般记为 s=“a1a2···an”(n>=0).它是编程语言中表示文本的数据类型.在程序设计中,字符串(string)为符号或数 ...
随机推荐
- RHEL6.5上升级OpenSSH7.4p1
由于升级OpenSSH涉及到安全性问题,为保险起见,在升级前最好安装telnet服务作为备用方案,然后在升级成功后再停止telnet即可. 一.OpenSSH升级相关源码包下载地址 zlib htt ...
- 九度oj 题目1135:字符串排序
题目描述: 先输入你要输入的字符串的个数.然后换行输入该组字符串.每个字符串以回车结束,每个字符串少于一百个字符. 如果在输入过程中输入的一个字符串为“stop”,也结束输入. 然后将这输入的该组字符 ...
- AFNetWorking出现code=-1016错误解决办法
报错类似: 2015-12-09 15:58:03.062 Carloans[14328:2300485] Error Domain=com.alamofire.error.serialization ...
- 【Luogu】P1072Hankson的趣味题(gcd)
这题真TM的趣味. 可以说我的动手能力还是不行,想到了算法却写不出来.以后说自己数论会GCD的时候只好虚了…… 我们首先这么想. x与a0的最大公约数为a1,那么我们把x/=a1,a0/=a1之后,x ...
- HDU 1693 Eat the Trees ——插头DP
[题目分析] 吃树. 直接插头DP,算是一道真正的入门题目. 0/1表示有没有插头 [代码] #include <cstdio> #include <cstring> #inc ...
- Linux(13):期中架构(5)--- 前端部分:keepalived高可用 & HTTPS & iptables防火墙
keepalived 高可用集群 1. keepalived服务概念说明 # 1.1 keepalived软件的作用? Keepalived软件起初是专为LVS负载均衡软件设计的, 用来管理并监控LV ...
- laravel 操作数据库
建立student控制器,控制器代码 namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class StudentC ...
- golang-random随机数
在Golang中,有两个包提供了rand,分别为 "math/rand" 和 "crypto/rand", 对应两种应用场景. 一."math/ra ...
- hdu3491最小割转最大流+拆点
题意:求最小割,即求最大流即可.此题之关键为拆点(限制在点),每条边都是双向边,注意一下. 未1A原因:在拆点之后添加边的过程中,要注意,出去的是i`,进来的是i,!!所以,写addegde函数时候 ...
- 使用javaconfig方式配置spring工程的单元测试
添加@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {MoveModelSpringTestConfig ...