21、e则说明是空map
7. 数据的删除
这里要用到erase函数,它有三个重载了的函数
迭代器删除
iter = mapStudent.find(1);
mapStudent.erase(iter);
用关键字删除
int n = mapStudent.erase(1);//如果删除了会返回1,否则返回0
用迭代器,成片的删除
一下代码把整个map清空
mapStudent.earse(mapStudent.begin(), mapStudent.en
22、d());
//成片删除要注意的是,也是STL的特性,删除区间是一个前闭后开的集合
8.其他一些函数用法
这里有swap,key_comp,value_comp,get_allocator等函数;
map的基本操作函数:
C++ Maps是一种关联式容器,包含“关键字/值”对
begin() 返回指向map头部的迭代器
clear() 删除所有元素
count() 返回指定元素出现的次数
empty() 如果map为空则
23、返回true
end() 返回指向map末尾的迭代器
equal_range() 返回特殊条目的迭代器对
erase() 删除一个元素
find() 查找一个元素
get_allocator() 返回map的配置器
insert() 插入元素
key_comp() 返回比较元素key的函数
lower_bound() 返回键值>=给定元素的第一个位置
max_size(
24、) 返回可以容纳的最大元素个数
rbegin() 返回一个指向map尾部的逆向迭代器
rend() 返回一个指向map头部的逆向迭代器
size() 返回map中元素的个数
swap() 交换两个map
upper_bound() 返回键值>给定元素的第一个位置
value_comp() 返回比较元素value的函
三. set
set是集合,set中不会包含重复的元素,这是和vector的区别。
25、
定义:
定义一个元素为整数的集合a,可以用 set a;
1,set的含义是集合,它是一个有序的容器,里面的元素都是排序好的,支持插入,删除,查找等操作,就像一个集合一样。所有的操作的都是严格在logn时间之内完成,效率非常高。 set和multiset的区别是:set插入的元素不能相同,但是multiset可以相同。
set的基本操作:
1. begin() 返回指向第一个元素的迭代器
2. clear() 清除所有元素
3. count() 返回某个值元素的个数
4. empty() 如果集合为
26、空,返回true
5. end() 返回指向最后一个元素的迭代器
6. equal_range() 返回集合中与给定值相等的上下限的两个迭代器
7. erase() 删除集合中的元素
8. find() 返回一个指向被查找到元素的迭代器
9. get_allocator() 返回集合的分配器
10.insert() 在集合中插入元素
11.lower_bound() 返回指向大于(或等于)某值的第一个元素的迭代器
12.key_comp() 返回一个用于元素间值比较的函数
13.max_si
27、ze() 返回集合能容纳的元素的最大限值
14.rbegin() 返回指向集合中最后一个元素的反向迭代器
15.rend() 返回指向集合中第一个元素的反向迭代器
16.size() 集合中元素的数目
17.swap() 交换两个集合变量
18.upper_bound() 返回大于某个值元素的迭代器
19.value_comp() 返回一个用于比较元素间的值的函数
set的遍历
代码如下:
1. setss;
2. set::iterator
28、it;
3. for(it = ss.begin(); it != ss.end(); it++)
4. {
5. printf("%d ",*it);
6. }
set的查找
1. int main()
2. {
3. set setStudent;
4. setStudent.insert(“student_one”);
5. setStudent.insert(“st
29、udent_two”);
6. setStudent.insert(“student_three”);
7. set::iterator iter;
8. iter = setStudent.find(“student_one”);
9. if(iter != setStudent.end())
10. {
11. cout<<”Found”<