C++ map

C++ map,第1张

C++ map 简介

map是STL的一个关联容器,它提供一对一的hash。

  • 第一个可以称为关键字(key),每个关键字只能在map中出现一次;
  • 第二个可能称为该关键字的值(value);

使用map得包含map类所在的头文件

#include //注意,STL头文件没有扩展名.h

map对象是模板类,需要关键字和存储对象两个模板参数:

std:map personnel;

这样就定义了一个用int作为索引,并拥有相关联的指向string的指针.

基本函数操作 一、插入操作 1、使用[ ]进行单个插入
map ID_Name;

// 如果已经存在键值2015,则会作赋值修改操作,如果没有则插入
ID_Name[2015] = "Tom";
2、使用insert进行单个和多个插入
// 插入单个键值对,并返回插入位置和成功标志,插入位置已经存在值时,插入失败
pair insert (const value_type& val);

//在指定位置插入,在不同位置插入效率是不一样的,因为涉及到重排
iterator insert (const_iterator position, const value_type& val);

// 插入多个
void insert (InputIterator first, InputIterator last);

//c++11开始支持,使用列表插入多个   
void insert (initializer_list il);

示例:

#include 
#include 

int main()
{
    std::map mymap;

    // 插入单个值
    mymap.insert(std::pair('a', 100));
    mymap.insert(std::pair('z', 200));

    //返回插入位置以及是否插入成功
    std::pair::iterator, bool> ret;
    ret = mymap.insert(std::pair('z', 500));
    if (ret.second == false) {
        std::cout << "element 'z' already existed";
        std::cout << " with a value of " << ret.first->second << '\n';
    }

    //指定位置插入
    std::map::iterator it = mymap.begin();
    mymap.insert(it, std::pair('b', 300));  //效率更高
    mymap.insert(it, std::pair('c', 400));  //效率非最高

    //范围多值插入
    std::map anothermap;
    anothermap.insert(mymap.begin(), mymap.find('c'));

    // 列表形式插入
    anothermap.insert({ { 'd', 100 }, {'e', 200} });

    return 0;
}

代码运行结果如下:

element ‘z’ already existed with a value of 200

二、取值

Map中元素取值主要有at和[ ]两种操作,at会作下标检查,而[]不会

map ID_Name;

//ID_Name中没有关键字2016,使用[]取值会导致插入
//因此,下面语句不会报错,但打印结果为空
cout<
三、容量查询
// 查询map是否为空
bool empty();

// 查询map中键值对的数量
size_t size();

// 查询map所能包含的最大键值对数量,和系统和应用库有关。
// 此外,这并不意味着用户一定可以存这么多,很可能还没达到就已经开辟内存失败了
size_t max_size();

// 查询关键字为key的元素的个数,在map里结果非0即1
size_t count( const Key& key ) const; //
四、迭代器

共有八个获取迭代器的函数:* begin, end, rbegin,rend* 以及对应的 * cbegin, cend, crbegin,crend*。

二者的区别在于,后者一定返回 const_iterator,而前者则根据map的类型返回iterator 或者 const_iterator。const情况下,不允许对值进行修改。如下面代码所示:

map::iterator it;
map mmap;
const map const_mmap;

it = mmap.begin(); //iterator
mmap.cbegin(); //const_iterator

const_mmap.begin(); //const_iterator
const_mmap.cbegin(); //const_iterator

返回的迭代器可以进行加减操作,此外,如果map为空,则 begin = end。

五、删除与交换 1、删除
// 删除迭代器指向位置的键值对,并返回一个指向下一元素的迭代器
iterator erase( iterator pos )

// 删除一定范围内的元素,并返回一个指向下一元素的迭代器
iterator erase( const_iterator first, const_iterator last );

// 根据Key来进行删除, 返回删除的元素数量,在map里结果非0即1
size_t erase( const key_type& key );

// 清空map,清空后的size为0
void clear();
2、交换
// 就是两个map的内容互换
void swap( map& other );
六、顺序比较
// 比较两个关键字在map中位置的先后
key_compare key_comp() const;

示例:

map mymap;
map::key_compare mycomp = mymap.key_comp();

mymap['a']=100;
mymap['b']=200;
mycomp('a', 'b');  // a排在b前面,因此返回结果为true
七、查找
// 关键字查询,找到则返回指向该关键字的迭代器,否则返回指向end的迭代器
// 根据map的类型,返回的迭代器为 iterator 或者 const_iterator
iterator find (const key_type& k);
const_iterator find (const key_type& k) const;

示例:

std::map mymap;
std::map::iterator it;

mymap['a']=50;
mymap['b']=100;
mymap['c']=150;
mymap['d']=200;

it = mymap.find('b');
if (it != mymap.end())
    mymap.erase (it); // b被成功删除
八、map对象的定义和初始化

map是键-值对的组合,有以下的一些定义的方法:

  • map m;

  • map m(m2);

  • map m(b, e);

上述第一种方法定义了一个名为m的空的map对象;第二种方法创建了m2的副本m;第三种方法创建了map对象m,并且存储迭代器b和e范围内的所有元素的副本。

map的value_type是存储元素的键以及值的pair类型,键为const。

补充:pair 1.1、pair类型的定义和初始化

pair类型是在有文件utility中定义的,pair类型包含了两个数据值,通常有以下的一些定义和初始化的一些方法:

  • pair p;//定义了一个空的pair对象p
  • pair p(v1, v2);//定义了包含初始值为v1和v2的pair对象p
  • make_pair(v1, v2);//以v1和v2值创建的一个新的pair对象。
1.2、pair对象的一些操作

除此之外,pair对象还有一些方法,如取出pair对象中的每一个成员的值:

  • p.first
  • p.second

示例:

#include 
#include 
#include 
#include 
using namespace std;

int main(){
        pair p1(0, "Hello");
        printf("%d, %s\n", p1.first, p1.second.c_str());
        pair p2 = make_pair(1, "World");
        printf("%d, %s\n", p2.first, p2.second.c_str());
        return 0;
}

代码运行结果如下:

0, Hello

1, World

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/2991816.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-23
下一篇 2022-09-23

随机推荐

  • 职务一般填什么

    职务要根据实际情况而填,有领导职务的可填写实际领导职务,职务较多的,则只填最高最主要的职务,专业技术人员可填写专业技术职称,没有职务的按照所从事的职业填写,如农民、学生等。职务要根据实际情况而填,有领

    2022-09-30
    0 0 0
  • 老蒯在东北是什么意思

    老蒯在东北是对年老妻子的一种叫法,带有一定的爱意。这个词多在东北农村乡土民情的作品中使用,现实生活很少有人用到。该词另一层意思是指行过房的女人。蒯是多年生草本植物,生老蒯在东北是对年老妻子的一种叫法,

    2022-09-30
    0 0 0
  • 防蚊贴能重复使用吗

    防蚊贴能重复使用吗是时下很多人都有的疑问,虽说该物品定价一般一盒20片装的驱蚊贴的价格在10元左右,但是长此以往下去还是一笔不小的开销,下面小编就和大家一起来探讨下。1、防蚊贴能重复使用吗是时下很多人

    2022-09-30
    0 0 0
  • 玉田县景点

    玉田县景点有江浩故居、孟家泉遗址、麻山寺旅游区、玉田老龙潭、古人种玉处等。1、江浩故居:位于玉田县城东南12公里的散水头镇北刘家桥村,东距乡间油路0.5公里,北望京秦电气化玉田县景点有江浩故居、孟家泉

  • 读书日的由来

    读书日的由来,4月23日世界读书日全称&ldquo;世界图书与版权日&rdquo;,又称&ldquo;世界图书日&rdquo;。最初的创意来自于国际出版商协会。由西班牙转交方案给了联合国教科文组读书日

    2022-09-30
    0 0 0
  • 愿往后余生的暖心句子

    1、许你一见如故,余生请多指教2、车马很慢,阳光很暖,你很好看。3、愿往后余生,独处是一个宇宙,相聚是一片星光。4、你如此美好,我跌入花间忘了人间。5、愿往后余生,始终保有初心模1、许你一见如故,余生

    2022-09-30
    0 0 0
  • 辛德瑞拉的含义

    “辛德瑞拉”指代灰姑娘似的女孩或者爱情。《灰姑娘》最经典的版本出自《格林兄弟》。这个版本中,帮助灰姑娘参加舞会的不是仙女而是母亲坟头的许愿树。为灰姑娘带来幸运的是“辛德瑞拉”指代灰姑娘似的女孩或者爱情

    2022-09-30
    0 0 0
  • 自热饭加热包的水喷到饭里可以吃吗

    自热饭是现在很常见的,不少人出去旅游都会带上自热锅,有的是火锅有的是米饭。那么,自热饭加热包的水喷到饭里可以吃吗?建议不要,这种是有化学物质的,吃了对人体不好,一般在加水加热自热饭是现在很常见的,不少

  • 羊毛大衣质量怎么看 羊绒大衣如何看质量

    1、大衣的主要表面部位无明显织疵、条痕(主要表面部位指大身的外露部位)。2、大衣的主要缝接部位无色差(需要在一定的光亮度下看色差情况)。3、大衣面料和里料结构应紧密,如1、大衣的主要表面部位无明显织疵

发表评论

登录后才能评论

评论列表(0条)