set
set
- set是按照一定次序存储元素的容器
- 在set中,元素的value也标识它(value就是key,类型为T),并且每个value必须是唯一的。set中的元素不能在容器中修改(元素总是const),但是可以从容器中插入或删除它们。
- 在内部,set中的元素总是按照其内部比较对象(类型比较)所指示的特定严格弱排序准则进行排序。
- set中插入元素时,只需要插入value即可,不需要构造键值对。
- set中的元素不可以重复(因此可以使用set进行去重)。
- 使用set的迭代器遍历set中的元素,可以得到有序序列
- set中的元素默认按照小于来比较
- set中查找某个元素,时间复杂度为:log₂n
- set中的元素不允许修改
- set中的底层使用二叉搜索树(红黑树)来实现。
set的接口介绍
Iterator | 接口 |
---|---|
begin() | set的起始位置(二叉搜索树的最左节点) |
end() | set的结束位置 |
rbegin() | 反向迭代器的起始位置 |
rend() | 反向迭代器的结束位置 |
Capacity | 接口 |
---|---|
empty() | 判断set是否为空 |
size() | 返回当前set中有效元素个数 |
max_size() | 返回当前set最大可存储多少个有效元素 |
Modifiers | 接口 |
---|---|
insert() | 插入一个新的元素 |
erase() | 删除指定元素 |
swap() | 交换两个set的内容 |
clear() | 清空有效字符 |
Operations | 接口 |
---|---|
find() | 返回指定元素的位置 |
set的实际操作
void TestSet()
{
int array[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0, 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };
set<int> s(array, array + sizeof(array) / sizeof(array[0]));//构造新的set
cout << s.size() << endl;
// 正向打印set中的元素,从打印结果中可以看出:set可去重
for (auto& e : s)
cout << e << " ";
cout << endl;
// 使用迭代器逆向打印set中的元素
for (auto it = s.rbegin(); it != s.rend(); ++it)
cout << *it << " ";
cout << endl;
s.erase(s.find(3));
for (auto& e : s)
cout << e << " ";
cout << endl;
return;
}
multiset
multiset与set基本一样,有区别的是multiset里面允许重复的元素出现,因而可以可以使用一个接口
count();//返回指定元素在set中的个数
其实set中也有这个函数,不过意义不大,因为set中不允许重复元素出现,所以没必要计数。
multiset操作
int array[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0, 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };
multiset<int> s(array, array + sizeof(array) / sizeof(array[0]));
cout << s.size() << endl;
// 正向打印set中的元素,从打印结果中可以看出:set可去重
for (auto& e : s)
cout << e << " ";
cout << endl;
// 使用迭代器逆向打印set中的元素
for (auto it = s.rbegin(); it != s.rend(); ++it)
cout << *it << " ";
cout << endl;
s.erase(s.find(3));
for (auto& e : s)
cout << e << " ";
cout << endl;
cout << s.count(2) << endl;
return;
map
map
- map是关联容器,它按照特定的次序(按照key来比较)存储由键值key和值value组合而成的元素。
- 在map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的内容。键值
key和值value的类型可能不同,并且在map的内部,key与value通过成员类型value_type绑定在一起,
为其取别名称为pair: - 在内部,map中的元素总是按照键值key进行比较排序的。
- map支持下标访问符,即在[]中放入key,就可以找到与key对应的value。
- map通常被实现为二叉搜索树(更准确的说:平衡二叉搜索树(红黑树)。
map接口介绍
Iterator | 接口 |
---|---|
begin() | map的起始位置 |
end() | map的结束位置 |
rbegin() | 反向迭代器的起始位置 |
rend() | 反向迭代器的结束位置 |
Capacity | 接口 |
---|---|
empty() | 判断map是否为空 |
size() | 返回当前map中有效元素个数 |
max_size() | 返回当前map最大可存储多少个有效元素 |
Modifiers | 接口 |
---|---|
insert() | 插入一个新的元素 |
erase() | 删除指定元素 |
swap() | 交换两个map的内容 |
clear() | 清空有效字符 |
Operations | 接口 |
---|---|
find() | 返回指定元素的位置 |
map有一个重要的接口"[]",重载了[]运算符
这使得我们在对map的插入与修改key对应的value的值的时候方便了许多。
map的操作
void TestMap()
{
map<string, int> m;
m.insert(pair<string, int>("苹果", 1));
m.insert(pair<string, int>("苹果", 1));//重复插入,map自动去重
m.insert(pair<string, int>("香蕉", 1));
m.insert(pair<string, int>("桃子", 1));
m.insert(pair<string, int>("梨", 1));//插入元素
for (auto e : m) {
cout << e.first << ":" << e.second << endl;
}
m["苹果"]++;//map中有对应key值,则对value值++
m["橘子"]++;//map中没有对应key值,先插入key,在对value值++
for (auto e : m) {
cout << e.first << ":" << e.second << endl;
}
}
注意在插入时使用了pair,pair是为了让key和value组成一对然后插入到map中
multimap
与multimap类似,multimap可以插入重复元素。但是multimap没有[]运算符重载(重复元素不可以通过key确定为具体哪一个)。
void TestMap()
{
multimap<string, int> m;
m.insert(pair<string, int>("苹果", 1));
m.insert(pair<string, int>("苹果", 1));//重复插入,map自动去重
m.insert(pair<string, int>("香蕉", 1));
m.insert(pair<string, int>("桃子", 1));
m.insert(pair<string, int>("梨", 1));//插入元素
for (auto e : m) {
cout << e.first << ":" << e.second << endl;
}
}