map和set只允许相同的键出现一次,而multimap和multiset则允许出现多次。

1. 引言——pair类型:

pair需要添加头文件utility头文件

make_pair<v1,v2> 以值v1和v2创建一个新的pair对象,这个pair对象的两个类型为这两个值的类型

pair<T1,T2>(v1,v2)

pair<T1,T2>  若是创建pair对象时不提供初始化式,则采用默认的构造函数来初始化

p·first p·second  这两个数据成员都是共有的数据成员

2. map类型

map必须包含map头文件

对于键类型唯一的约束就是必须支持<操作符。

必须在键类型上定义严格的弱排序(即严格的在键上面存在小于关系)。

(1)map定义的类型

map<K,V>::key_type  键的类型。

map<K,V>::mapped_type 键所关联的值的类型。

map<K,V>::value_type 一个pair类型,但是键是const的不能被修改,即值可以修、修改,但是键不能被修改。

map迭代器的解引用得到的就是pair对象

(2)map添加新元素

下标访问map时,得到值mapped_value,当map中不存在这个键时相当于添加了这个键值对。

m·insert(e): 这里e为一个pair型的键值对

m·insert(beg,end):这里插入beg和end标记的范围内的元素,元素类型必须为m·value_type类型的元素

在map对象中一个给定的键只对应一个元素,在insert时,若是试图插入的元素的值已经在map中了,则不做任何事

(3)map查找元素

m·count(k):查找map对象m中键k是否出现(这里由于是map所以只可能是出现1或者没出现0)。

m·find(k):查找map对象m中的键k,若是有则返回指向键k的键值对的迭代器,若没有则返回最末端的迭代器m·end()

(4)m对象中删除元素

map容器的erase操作后返回的是void

而顺序容器的erase操作后返回的是指向删除元素的后面一个元素的迭代器

m·erase(k):删除键,返回size_type删除元素个数

m·erase(iter):删除迭代器iter所指向的元素,返回void

m·erase(iter1,iter2):删除这两个迭代器所标记的范围,

3.set类型

需要添加set头文件

set只是单纯的键的集合。

4.multimap和multiset类型

需要添加map或者set头文件

这里面map的一个键可能对应了多个值

还有set里面可能包含了多个相同的键

10.1——pair,map,set,multimap,multiset的更多相关文章

  1. 信1705-2 软工作业最大重复词查询思路: (1)将文章(一个字符串存储)按空格进行拆分(split)后,存储到一个字符串(单词)数组中。 (2)定义一个Map,key是字符串类型,保存单词;value是数字类型,保存该单词出现的次数。 (3)遍历(1)中得到的字符串数组,对于每一个单词,考察Map的key中是否出现过该单词,如果没出现过,map中增加一个元素,key为该单词,value为1(

    通过学习学会了文本的访问,了解一点哈希表用途.经过网上查找做成了下面查询文章重复词的JAVA程序. 1 思 思路: (1)将文章(一个字符串存储)按空格进行拆分(split)后,存储到一个字符串(单词 ...

  2. Java-list,set,map的区别

    jdk中api的定义 Collection ├----List │ ├----LinkedList │ ├----ArrayList │ └----Vector │ └----Stack └----S ...

  3. Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)...啊啊啊

    函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...

  4. (转)Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)

    原文:https://www.cnblogs.com/chenwolong/p/reduce.html 函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数 ...

  5. python高阶函数,map,filter,reduce,ord,以及lambda表达式

    为什么我突然扯出这么几个函数,是因为我今天在看流畅的python这本书的时候,里面有一部分内容看的有点懵逼. >>> symbols = '$¢£¥€¤' >>> ...

  6. spark 的一些常用函数 filter,map,flatMap,lookup ,reduce,groupByKey

    定义不带参数也不带返回值的函数(def :定义函数的关键字  printz:方法名称) scala> def printz = print("scala hello")   ...

  7. Map接口,Map.Entry,hashMap类,TreeMap类,WeakHashMap。

    Collection接口之前接触过,每次保存的对象是一个对象,但是在map中保存的是一对对象,是以key->value形式保存的. 定义: public interface Map<K,V ...

  8. Java中List,ArrayList、Vector,map,HashTable,HashMap区别用法

    Java中List,ArrayList.Vector,map,HashTable,HashMap区别用法 标签: vectorhashmaplistjavaiteratorinteger ArrayL ...

  9. 【转】java 容器类使用 Collection,Map,HashMap,hashTable,TreeMap,List,Vector,ArrayList的区别

    原文网址:http://www.360doc.com/content/15/0427/22/1709014_466468021.shtml java 容器类使用 Collection,Map,Hash ...

随机推荐

  1. swift Equatable 函数签名的测试

    struct Degoo:Equatable { var lex:String var pex:String static func == (left:Degoo, right:Degoo) -> ...

  2. XtraBackUp 热备份工具

    是一款强大的在线热备份工具 备份的过程中,不锁表 使用percona-xtrabackup-24-2.4.7-1.el7.x86_64.rpm yum源安装: 1.安装Percona的库:       ...

  3. dom和bom是什么?

    DOM:文档对象模型,描述了处理网页内容的方法和接口.最根本对象是document(window.document). 由于DOM的操作对象是文档,所以DOM和浏览器没有直接关系. 部署在服务器上的文 ...

  4. jmeter 接口测试简介

    前言: 本文主要针对http接口进行测试,使用Jmeter工具实现. Jmter工具设计之初是用于做性能测试的,它在实现对各种接口的调用方面已经做的比较成熟,因此,本次直接使用Jmeter工具来完成对 ...

  5. vue render {} 对象 说明文档

    Vue学习笔记进阶篇——Render函数 http://www.mamicode.com/info-detail-1906336.html 深入data object参数 有一件事要注意:正如在模板语 ...

  6. iview分析

  7. In line copy and paste to system clipboard

    On the Wiki Wiki Activity Random page Videos Photos Chat Community portal To do    Contribute  Watch ...

  8. mysql5.7zip安装

    一.下载mysql zip文件 二.解压.(我的目录A:\mysql\mysql-5.7.23-winx64) 三.配置环境变量   Path后面追加%A:\mysql\mysql-5.7.23-wi ...

  9. spring tool suite (sts) 创建springmvc(没有实践)

    摘自:STS(Spring Tool Suite)建立默认的spring mvc项目 老外的原创,网址:http://www.codejava.NET/frameworks/spring/spring ...

  10. vue 框架原理

    参考:https://segmentfault.com/a/1190000006599500#articleHeader4 记录自己的理解: 核心的响应原理通过Object.definePropert ...