- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Cmap的基本操作和使用
C++ map的基本操作和使用 Map是c++的一个标准容器,她提供了很好一对一的关系,在一些程序中建立一个map可以起到事半功倍的效果,总结了一些map基本简单实用的操作! 1、map简介 map是一类关联式容器。它的特点是增加和删除节点对迭代器的影响很小,除了那个操作节点,对其他的节点都没有什么影响。对于迭代器来说,可以修改实值,而不能修改key。 2、map的功能 自动建立Key - value的对应。key 和 value可以是任意你需要的类型。 根据key值快速查找记录,查找的复杂度基本是Log(N),如果有1000个记录,最多查找10次,1,000,000个记录,最多查找20次。 快速插入Key - Value 记录。 快速删除记录 根据Key 修改value记录。 遍历所有记录。 3、使用map 使用map得包含map类所在的头文件 #include map //注意,STL头文件没有扩展名.h map对象是模板类,需要关键字和存储对象两个模板参数: std:mapint, string personnel; 这样就定义了一个用int作为索引,并拥有相关联的指向string的指针. 为了使用方便,可以对模板类进行一下类型定义, typedef mapint, CString UDT_MAP_INT_CSTRING; UDT_MAP_INT_CSTRING enumMap; 4、在map中插入元素 改变map中的条目非常简单,因为map类已经对[]操作符进行了重载 enumMap[1] = One; enumMap[2] = Two; ..... 这样非常直观,但存在一个性能的问题。插入2时,先在enumMap中查找主键为2的项,没发现,然后将一个新的对象插入enumMap,键是2, 值是一个空字符串,插入完成后,将字符串赋为Two; 该方法会将每个值都赋为缺省值,然后再赋为显示的值,如果元素是类对象,则开销比较大。我们可以用以下方法来避免开销: enumMap.insert(mapint, CString :: value_type(2, Two)) 5、查找并获取map中的元素 下标操作符给出了获得一个值的最简单方法: CString tmp = enumMap[2]; 但是,只有当map中有这个键的实例时才对,否则会自动插入一个实例,值为初始化值。 我们可以使用Find()和Count()方法来发现一个键是否存在。 查找map中是否包含某个关键字条目用find()方法,传入的参数是要查找的key,在这里需要提到的是begin()和end()两个成员,分别代表map对象中第一个条目和最后一个条目,这两个数据的类型是iterator. int nFindKey = 2; //要查找的Key //定义一个条目变量(实际是指针) UDT_MAP_INT_CSTRING::iterator it= enumMap.find(nFindKey); if(it == enumMap.end()) { //没找到 } else { //找到 } 通过map对象的方法获取的iterator数据类型是一个std::pair对象,包括两个数据 iterator-first 和 iterator-second 分别代表关键字和存储的数据 6、从map中删除元素 移除某个map中某个条目用erase() 该成员方法的定义如下 iterator erase(iterator it); //通过一个条目对象删除 iterator erase(iterator first, iterator last); //删除一个范围 size_type erase(const Key key); //通过关键字删除 clear()就相当于 enumMap.erase(enumMap.begin(), enumMap.end()); 1. map最基本的构造函数; mapstring , int mapstring; mapint ,string mapint; mapsring, charmapstring; map char ,stringmapchar; mapchar ,intmapchar; mapint ,char mapint; 2. map添加数据; mapint ,string maplive; 1.maplive.insert(pairint,string(102,aclive)); 2.maplive.insert(mapint,string::value_type(321,hai)); 3, maplive[112]=April;//map中最
您可能关注的文档
最近下载
- 建筑垃圾资源化处理技术探讨.docx VIP
- 江苏开放大学大学英语(B)(1) 060051过程性考核作业2.docx VIP
- 聚脲施工方案(DOC).docx
- 美国微机保护装置SEL-387L指导手册20040412.pdf VIP
- T /SIA 047—2025 人工智能开发工程师能力评价标准.pdf VIP
- ZXDT02-PU(V2.5)光伏功率模块 用户手册.pdf VIP
- 高教马工程知识产权法学(第二版)教学课件06.pptx VIP
- 2025年鼠疫防控测试题及答案.doc VIP
- 半导体物理:第五章 半导体的电导现象和霍尔效应.pptx VIP
- 2024(统编版选必1)历史 第三单元 法律与教化 教材解读课件.pptx
文档评论(0)