博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深度理解STL之map、set
阅读量:6361 次
发布时间:2019-06-23

本文共 806 字,大约阅读时间需要 2 分钟。

 

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

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的函数

 

转载于:https://www.cnblogs.com/BobHuang/p/6974073.html

你可能感兴趣的文章
jquery 操作DOM 案例
查看>>
sql 高级查询语句总结
查看>>
小技巧css解决移动端ios不兼容position:fixed属性,无需插件
查看>>
android 多线程的实现方式
查看>>
面试---Python中的模块和包是什么?
查看>>
Unity3D 学习教程 10 复制物体
查看>>
Google+ 连接不上的解决办法
查看>>
“.NET技术”使用WCF实现SOA面向服务编程—— 架构设计
查看>>
有关云计算安全的两大谎言
查看>>
互联网公司成功的四个要点,互联网营销
查看>>
Flex 4 和 Flash Builder 4 正式版发布 采用全新的Spark组件架构
查看>>
HTML5标准将在2014年完成
查看>>
艾伟_转载:ASP.NET中写自定义的Config Provider
查看>>
mac系统小记
查看>>
《软件设计师》——法律法规与标准化知识
查看>>
KSImageNamed-Xcode-master 对项目中图片提供自动提示功能的插件
查看>>
PS切图
查看>>
交流的人生感悟
查看>>
2ms系统项目总结
查看>>
说说自己对于原型链 __proto__ prototype constructor的理解
查看>>