我是靠谱客的博主 热心皮卡丘,最近开发中收集的这篇文章主要介绍STL标准模板库 --- map标准模板库STL之map,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

标准模板库STL之map

https://www.w3cschool.cn/cpp/cpp-fu8l2ppt.html

一、Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候,在编程上提供快速通道。这里说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的,后边我们会见识到有序的好处。

二、map具体代码实现

1、map最基本的构造函数;

   map<string , int >mapstring;         map<int ,string >mapint;

   map<sring, char>mapstring;         map< char ,string>mapchar;

   map<char ,int>mapchar;            map<int ,char >mapint;

 

2、map添加数据;


  1. map< int , string> maplive;
  2. 1.maplive.insert(pair< int, string>( 102, "aclive"));
  3. 2.maplive.insert( map< int, string>::value_type( 321, "hai"));
  4. 3, maplive[ 112]= "April"; //map中最简单最常用的插入添加!

3、map中元素的查找:

   find()函数返回一个迭代器指向键值为key的元素,如果没找到就返回指向map尾部的迭代器。        


  1. map< int , string >::iterator l_it;;
  2. l_it=maplive.find( 112);
  3. if(l_it==maplive.end())
  4. cout<< "we do not find 112"<< endl;
  5. else cout<< "wo find 112"<< endl;

 

4、map中元素的删除:

   如果删除112;


  1. map< int , string >::iterator l_it;;
  2. l_it=maplive.find( 112);
  3. if(l_it==maplive.end())
  4. cout<< "we do not find 112"<< endl;
  5. else maplive.erase(l_it); //delete 112;

5、map的基本操作函数:

    C++ Maps是一种关联式容器,包含“关键字/值”对

    begin()          返回指向map头部的迭代器

    clear()         删除所有元素

    begin()          返回指向map头部的迭代器

    clear()         删除所有元素

    count()          返回指定元素出现的次数

    empty()          如果map为空则返回true

    end()            返回指向map末尾的迭代器

    equal_range()    返回特殊条目的迭代器对

    erase()          删除一个元素

    find()           查找一个元素

    get_allocator()  返回map的配置器

    insert()         插入元素

    key_comp()       返回比较元素key的函数

    lower_bound()    返回键值>=给定元素的第一个位置

    max_size()       返回可以容纳的最大元素个数

    rbegin()         返回一个指向map尾部的逆向迭代器

    rend()           返回一个指向map头部的逆向迭代器

    size()           返回map中元素的个数

    swap()            交换两个map

    upper_bound()     返回键值>给定元素的第一个位置

    value_comp()      返回比较元素value的函数

 

 

最后

以上就是热心皮卡丘为你收集整理的STL标准模板库 --- map标准模板库STL之map的全部内容,希望文章能够帮你解决STL标准模板库 --- map标准模板库STL之map所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(66)

评论列表共有 0 条评论

立即
投稿
返回
顶部