zoukankan      html  css  js  c++  java
  • 我不熟悉的map

    讲map之前,其实很多都在set那篇讲过了。我不熟悉的set

    很多的API都类似,不会再累述。

    map和set都是用红黑树实现的,但是set只能存单个值,它的key和value都是同一个,map不一样,它的每一个key都映射一个value.

    接下来先介绍一些map自己的东西,再把和set一样的提一下。

    四种插入新键值对的方式

    现在我们定义一个空的map:

    map<int,string> m;
    

    下面展示四种方式。

    一、pair方式

    m.insert(pair<int,string>(10,"Tom"));
    

    这是通过创建一个pair的匿名对象来保存数据。

    二、make_pair

    m.insert(make_pair(0,"Jerry"));
    

    我们知道,make_pair就返回一个对组,这个对组就能直接赋值给map。

    三、value_type方式

    m.insert(map<int,string>::value_type(1,"Super"));
    

    通过map内置的一个value_type来赋值。

    四、直接插入

    m[9] = "John";
    

    这个方法看起来是最简单的,却暗藏杀机。当我们写以下语句:

    m[100];
    

    我们没有给它一个value,本意可能不想插入,但是一旦我们这么写,它就会给我们默认插进去,value为默认值。所以这个方法很可能使用不当。所以建议采用第二种创建方式,比较短,而且不容易出错。

    如果访问key和value

    map保存了两个值,提供了first和second两个函数来访问key和value,互相对应。

    如下:

    int main()
    {
        map<int, string> m;
    	m.insert(make_pair(0, "Jerry"));
    	m.insert(map<int, string>::value_type(1, "Super"));
    	m[9] = "John";
    	m[100];
    	for (auto mapIt = m.begin(); mapIt != m.end(); ++mapIt)
    		cout << "key:" << mapIt->first << " value:" << mapIt->second << endl;
    	return 0;
    }
    

    输出:

    可以看到:

    • 同样也以key排好序了。
    • 且m[100]也插入了一个空。
    • 我们通过迭代器调用了second和first来访问key和value。

    同样的,插入也返回一个pair<iterator,bool>类型。

    指定规则排序

    与set无异,在创建的同时就指定排序规则。将上述代码中,声明m的语句改为:

    // MyCmp是仿函数。
    map<int,string,MyCmp> m;
    

    其它操作

    查找操作

    与set无异。

    find(key);     //查找键key是否存在,若存在,返回该键的元素的迭代器;/若不存在,返回map.end();
    count(keyElem);//返回容器中key为keyElem的对组个数。对map来说,要么是0,要么是1。对multimap来说,值可能大于1。
    lower_bound(keyElem);//返回第一个key>=keyElem元素的迭代器。
    upper_bound(keyElem);//返回第一个key>keyElem元素的迭代器。
    equal_range(keyElem);//返回容器中key与keyElem相等的上下限的两个迭代器。
    

    大小操作

    size();//返回容器中元素的数目
    empty();//判断容器是否为空
    

    与set无异。

    删除操作

    clear();    //删除所有元素
    erase(pos); //删除pos迭代器所指的元素,返回下一个元素的迭代器。
    erase(beg,end);//删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。
    erase(keyElem);//删除容器中key为keyElem的对组。
    

    与set无异。

  • 相关阅读:
    [转载]写作经验谈--如何写一本书?
    决定写一本书
    c中自定义函数通过sizeof来输出数组的长度为何不正确?【原创】
    [转]关于PHP的漏洞以及如何防止PHP漏洞?
    [转]PHP安全之防止你的源代码或重要配置信息暴露在外
    PHPUnit 单元测试框架(鸡肋)
    [转]避免PHP-FPM内存泄漏导致内存耗尽
    [转]PHP ffmpeg截取视频指定帧为图片,获取rotation信息并旋转
    ThinkPHP 缓存 以及Zend OPCache提升PHP性能
    简单测漏 语句
  • 原文地址:https://www.cnblogs.com/love-jelly-pig/p/9995967.html
Copyright © 2011-2022 走看看