C++ Multimaps和maps很相似,但是MultiMaps允许重复的元素。(具体用法请参考map容器)
    函数列表:
    begin() 返回指向第一个元素的迭代器 
    clear() 删除所有元素 
    count() 返回一个元素出现的次数 
    empty() 如果multimap为空则返回真 
    end() 返回一个指向multimap末尾的迭代器 
    equal_range() 返回指向元素的key为指定值的迭代器对 
    erase() 删除元素 
    find() 查找元素 
    get_allocator() 返回multimap的配置器 
    insert() 插入元素 
    key_comp() 返回比较key的函数 
    lower_bound() 返回键值>=给定元素的第一个位置 
    max_size() 返回可以容纳的最大元素个数 
    rbegin() 返回一个指向mulitmap尾部的逆向迭代器 
    rend() 返回一个指向multimap头部的逆向迭代器 
    size() 返回multimap中元素的个数 
    swap() 交换两个multimaps 
    upper_bound() 返回键值>给定元素的第一个位置 
    value_comp() 返回比较元素value的函数
    
    ////////////////////////////////////////////////////////////////////////////////////
    构造函数
    explicit multimap(const Pred& comp = Pred(), const A& al = A());
    multimap(const multimap& x);
    multimap(const value_type *first, const value_type *last,
    const Pred& comp = Pred(), const A& al = A());
    
    begin 
    语法: 
      iterator begin();
    begin()函数返回一个迭代器,指向multimap的第一个元素。
    clear 
    语法: 
      void clear();
    clear()函数删除multimap中的所有元素。
    count 
    语法: 
      size_type count( const key_type &key );
    count()函数返回multimap中键值等于key的元素的个数。
    empty 
    语法: 
      bool empty();
    empty()函数返回真(true)如果multimap为空,否则返回假(false)。
    end 
    语法: 
      iterator end();
    end()函数返回一个迭代器,指向multimap的尾部。
    equal_range 
    语法: 
      pair equal_range( const key_type &key );
    equal_range()函数查找multimap中键值等于key的所有元素,返回指示范围的两个迭代器。
    erase 
    语法: 
      void erase( iterator pos );
      void erase( iterator start, iterator end );
      size_type erase( const key_type &key );
    erase()函数删除在pos位置的元素,或者删除在start和end之间的元素,或者删除那些值为key的所有元素。
    find 
    语法: 
      iterator find( const key_type &key );
    find()函数返回一个迭代器指向键值为key的元素,如果没找到就返回指向multimap尾部的迭代器。
    get_allocator 
    语法: 
      allocator_type get_allocator();
    get_allocator()函数返回multimap的配置器。
    insert 
    语法: 
      iterator insert( iterator pos, const TYPE &val );
      void insert( input_iterator start, input_iterator end );
      pair insert( const TYPE &val );
    insert()函数:
    
    插入val到pos的后面,然后返回一个指向这个元素的迭代器。 
    插入start到end的元素到multimap中。 
    只有在val不存在时插入val。返回值是一个指向被插入元素的迭代器和一个描述是否插入的bool值。 
    key_comp 
    语法: 
      key_compare key_comp();
    key_comp()函数返回一个比较key的函数。
    lower_bound 
    语法: 
      iterator lower_bound( const key_type &key );
    lower_bound()函数返回一个迭代器,指向multimap中键值>=key的第一个元素。
    max_size 
    语法: 
      size_type max_size();
    max_size()函数返回multimap能够保存的最大元素个数。
    rbegin 
    语法: 
      reverse_iterator rbegin();
    rbegin()函数返回一个指向multimap尾部的逆向迭代器。
    rend 
    语法: 
      reverse_iterator rend();
    rend()函数返回一个指向multimap头部的逆向迭代器。
    size 
    语法: 
      size_type size();
    size()函数返回multimap中保存的元素个数。
    swap 
    语法: 
      void swap( multimap &obj );
    swap()交换obj和现mulitmap中的元素。
    upper_bound 
    语法: 
      iterator upper_bound( const key_type &key );
    upper_bound()函数返回一个迭代器,指向multimap中键值>key的第一个元素。
    value_comp 
    语法: 
      value_compare value_comp();
    value_comp()函数返回一个比较元素value的函数。
    示例:
    #include <iostream>
    #include <map>
    #include <string>
    using namespace std;
    void main()
    {
       multimap <string ,int> m;//multimap的创建
       m.insert(pair<string,int>("Jack",1));//插入
       m.insert(pair<string,int>("Jack",2));
       m.insert(pair<string,int>("Body",1));
       m.insert(pair<string,int>("Navy",4));
       m.insert(pair<string,int>("Demo",3));
     
       multimap<string,int>::iterator iter;
       for (iter = m.begin();iter != m.end();++iter)//遍历
       {
    cout<<(*iter).first<<"  "<<(*iter).second<<endl;
       }
       m.erase("Navy");//multimap的删除
       cout<<"The element after delete:"<<endl;
       for (iter = m.begin();iter != m.end();++iter)
       {
    cout<<(*iter).first<<"  "<<(*iter).second<<endl;
       }
       //multimap元素的查找 
       multimap<string,int>::iterator it;
       int num=m.count("Jack");
       it = m.find("Jack");
       cout<<"the search result is :"<<endl;
       for(int i=1;i<=num;i++)
       {
      cout<<(*it).first<<"  "<<(*it).second<<endl;
       it++;
       }
       if(i==1){ cout<<"can not find!"<<endl; }
    }
    输出结果:
    Body  1
    Demo  3
    Jack  1
    Jack  2
    Navy  4
    The element after delete:
    Body  1
    Demo  3
    Jack  1
    Jack  2
    the search result is :
    Jack  1
    Jack  2

标准模板库(STL)学习探究之Multimap容器的更多相关文章

  1. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  2. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  3. 标准模板库(STL)学习指南之sort排序

    对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...

  4. 标准模板库(STL)学习指南之List链表

    本文转载自天极网,原文地址:http://www.yesky.com/255/1910755.shtml.转载请注明 什么是STL呢?STL就是Standard Template Library,标准 ...

  5. 标准模板库(STL)学习指南之set集合

    set是关联容器.其键值就是实值,实值就是键值,不可以有重复,所以我们不能通过set的迭代器来改变set的元素的值,set拥有和list相同的特性:当对他进行插入和删除操作的时候,操作之前的迭代器依然 ...

  6. 标准模板库(STL)学习指南之priority_queue优先队列

    转载自CSDN博客:http://blog.csdn.net/suwei19870312/article/details/5294016 priority_queue 调用 STL里面的 make_h ...

  7. 标准模板库(STL)学习指南之map映射

    转载自CSDN博客:http://blog.csdn.net/bat603/article/details/1456141 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...

  8. 标准模板库(STL)学习指南之vector向量

    vector – 一.  vector可以模拟动态数组 – 二.  vector的元素可以是任意类型T,但必须具备赋值和拷贝能力(具有public 拷贝构造函数和重载的赋值操作符) 三.必须包含的头文 ...

  9. STL学习系列之一——标准模板库STL介绍

    库是一系列程序组件的集合,他们可以在不同的程序中重复使用.C++语言按照传统的习惯,提供了由各种各样的函数组成的库,用于完成诸如输入/输出.数学计算等功能. 1. STL介绍 标准模板库STL是当今每 ...

随机推荐

  1. python3 tkinter模块小项目联系之邮箱客户端

    # -*- coding:utf-8 -*- from tkinter import * from tkinter.messagebox import askyesno, showerror, sho ...

  2. rgba转化为16进制在线工具

    https://www.sioe.cn/yingyong/yanse-rgb-16/

  3. 看不到但摸得到的捣蛋鬼---Zero Width Space

    看不到但摸得到的捣蛋鬼---Zero Width Space 1.情况如何? 昨天,"某某某"的代码出现了一个bug.大概是这个情况: 有一个提示信息,需要展示,大概这样: 这行文 ...

  4. SQL join的示意图

    SQL join 用于把来自两个或多个表的行结合起来. 下图展示了 LEFT JOIN.RIGHT JOIN.INNER JOIN.OUTER JOIN 相关的 7 种用法. 注意JOIN要和ON相连 ...

  5. Myeclipse 崩溃闪退 Java was started but returned exit code =-1

    出现如上图所述情况的原因可能是因为虚拟机jdk和myEclipse配置文件中的vm地址发生冲突报出的错误 第一种解决办法:只需要将你jdk文件下的bin目录下的javaw.exe文件的全部路径复制到M ...

  6. SpringBoot 中定时执行注解(@Scheduled、@EnableScheduling)

    项目开发中经常需要执行一些定时任务,比如需要在每天凌晨时候,分析一次前一天的日志信息.Spring为我们提供了异步执行任务调度的方式,提供TaskExecutor .TaskScheduler 接口. ...

  7. 【leetcode】998. Maximum Binary Tree II

    题目如下: We are given the root node of a maximum tree: a tree where every node has a value greater than ...

  8. vi快捷操作

    全部删除: 按esc键后,先按gg(到达顶部),然后dG 全部复制: 按esc键后,先按gg,然后ggyG 全选高亮显示: 按esc键后,先按gg,然后ggvG或者ggVG 单行复制: 按esc键后, ...

  9. linux系统一些信息(待整理)

    Linux查看物理CPU个数.核数.逻辑CPU个数 复制代码 # 总核数 = 物理CPU个数 X 每颗物理CPU的核数 # 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数 ...

  10. 2019 TCO Round 1B——[ 状压DP ]

    第一题是 EllysSki . 题意:给n个数,求两个方向的最长递减区间. 可以O(n). #include<cstdio> #include<cstring> #includ ...