码迷,mamicode.com
首页 > 其他好文 > 详细

深度理解STL之map、set

时间:2017-06-09 23:42:16      阅读:271      评论:0      收藏:0      [点我收藏+]

标签:使用   nbsp   cti   log   并集   erase   upper   end   工作   

 

课程设计做了这个一直没有整理(搬运

set算是关键字和相同的特殊map

set应该更加被强调理解为“集合”,而集合所涉及的操作并、交、差等,即STL提供的如交集set_intersection()、并集set_union()、差集set_difference()和对称差集set_symmetric_difference(),都需要进行大量的比较工作,那么使用底层是有序结构的红黑树就十分恰当了,这也是其相对hash结构的优势所在。

Map是在红黑树基础上的Hash map,即存在唯一关键字与键值对应,还有mutimap,这种更依靠Hash算法,原理相同,值得一提的是set是键值和值相同的set。Maps 是一种关联式容器,包含“关键字/值”对

 

map的基本操作函数
begin() 返回指向map头部的迭代器
clear() 删除所有元素
count() 返回指定元素出现的次数
empty() 如果map为空则返回true
end() 返回指向map末尾的迭代器
equal_range() 返回特殊条目的迭代器对
erase() 删除一个元素
find() 查找一个元素
get_allocator() 返回map的配置器
insert() 插入元素
key_comp() 返回比较元素key的函数
lower_bound() 返回键值>=给定元素的第一个位置
upper_bound() 返回键值>给定元素的第一个位置
max_size() 返回可以容纳的最大元素个数
rbegin() 返回一个指向map尾部的逆向迭代器
rend() 返回一个指向map头部的逆向迭代器
size() 返回map中元素的个数
swap() 交换两个map
value_comp() 返回比较元素value的函数

技术分享

技术分享

技术分享

 

深度理解STL之map、set

标签:使用   nbsp   cti   log   并集   erase   upper   end   工作   

原文地址:http://www.cnblogs.com/BobHuang/p/6974073.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!