`
caiwb1990
  • 浏览: 315123 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

C++ Map小结

阅读更多

Map介绍
特点:
1.map将Key的object和T的Object绑定到一起,因此是一种Pair Associative Container, 表示其value type为 pair。
2.它同时也是Unique Associative Container,表示没有两个元素具有相同的Key。
3.它还是一种Sorted Associative Container,因此第三个参数只能是less,greater之类的functor, 相比较而言,
  hash table是 equal_to, not_equal_to之类的functor。

map常用的方法主要有:
insert,erease,size,count,begin,end,find,clear,empty

insert方法:
    在map中插入一个元素,map中记录的元素通常为键值对。所以,在存储时会把,键和值封装成pair然后进行插入。
    
    phone.insert(pair<string,string>(name,number));
    //其中name和number为string类型的变量。

    //当然也可以简单的写成
    phone[name]=number;
    //此处phone即为map<string,string>类型的变量。因为map在实现过程中对[]进行了重载。


    第一种方式若插入的元素的键值已经存在于map中,那么就会插入失败,不会修改元素的键值对信息,若键值在map中查找不到,那么就会将该新元素加入到map中去。
    第二种方式比较直观,但存在一个性能的问题。插入2时,先在phone中查找主键为name的项,没发现,然后将一个新的对象插入phone,键是name,值是一个空字符串,插入完成后,将字符串赋为number, 该方法会将每个值都赋为缺省值,然后再赋为显示的值,如果元素是类对象,则开销比较大。若找到键值为name的项,则用number更改原来的number值。

    map<string,string> map;
    
    int Test::input(string name,string number)  
    {  
        //map[name]=number;  
        map.insert(pair<string,string>(name,number));  
        return 0;  
    }    



erease方法:
erease主要是删除map中的某个项,需要参数key,例如phone.erease(name);此句的意思就是删除key值为name的键值对。


find方法:
    map<string,string> map;  
    int  Test::getNum(string name)
    {
	std::map<std::string, std::string>::iterator it = map.find(name);

	if(it == map.end()){  
		return -1;  
	}else{  
		return it->second;  
	}  
    }


size方法:
统计map中键值对的个数,phone.size()返回值即为phone中键值对的个数,若map为空则返回0

    map<string,string> map;  

   int Test::count(){  
       return map.size();  
   }  



count方法:
统计map中某个键值出现的次数,因为map中键值唯一,所以此方法可以用来检测某键值是否存在,例如在删除时可以phone.count(name),若为0则可以提示用户此键值不存在,若为1则直接删除。Ps:erease无论要删除的键值对是否存在都能正常执行。

    map<string,string> map;  



begin、end方法:
begin方法返回map迭代器类型,通过此迭代器与end方法的返回值进行比较就可以很容易的对map进行遍历。

    map<string,string> map;  

    int Test::showAll()  
    {  
        map<string,string>::iterator ite = map.begin();  
        while(ite!=phone.end()) {  
            cout<<ite->first<<"\t";  
            cout<<ite->second<<endl;  
            ite++;  
        }  
        return 0;  
    }  



clear方法:
清空map中的所有元素

    map<string,string> map;  
    int Test::clear()
    {
        map.clear();  
    }



empty方法:
判断map是否为空,若为空则返回真若非空则返回假。
Ps:由于map中存储的是键值对,迭代器为ite,则ite->first为key,ite->second为值

分享到:
评论

相关推荐

    C++ map 根据value找key的实现

    小结 在 C++ 中,我们可以使用 `std::find_if` 算法和 lambda 表达式或函数对象来实现根据 value 找到 key 的功能。这两种方法都可以达到我们的目的,但是函数对象可以使我们的代码更加灵活和可读。 知识点 * C++...

    c和c++的一些小结

    - C++标准库提供了大量的工具和容器(如std::vector, std::string, std::map等),合理使用可以提高代码质量。 5. **进一步学习建议**: - 掌握STL(Standard Template Library)是C++学习的重要阶段,了解容器、...

    map使用实例小结,VS2005运行通过

    在C++编程中,`std::map` 是一个关联容器,它存储键值对,并且按照键的顺序组织元素。在这个实例中,我们看到`map` 被用来存储整数(`int`)作为键和字符串(`string`)作为值,用于模拟学生信息的存储,例如学生的...

    Visual C++编程技巧小结

    - **STL(Standard Template Library)**:熟悉容器(如vector、list、map)、算法和迭代器,能大大提高代码的复用性和效率。 - **RAII(Resource Acquisition Is Initialization)**:理解如何利用智能指针(如...

    这是我学习C++的笔记,属于个人小结。

    标准库(Standard Library)提供了大量预定义的函数和类,例如输入输出流(iostream)、字符串处理(string)、容器(vector、list、map等)。在编写C++程序时,合理利用标准库可以显著提高开发效率。 ### 7. 指针...

    C++ STL 开发技术导引(第6章)

    1.12 本章小结 23 第2章 C++模板技术 25 2.1 函数模板 25 2.2 类模板 27 2.3 模板完全特化 28 2.4 函数模板重载 30 2.5 类模板继承 30 2.6 本章小结 31 第3章 C++ I/O流技术 32 3.1 I/O流类 32 ...

    C++ Primer中文版(第5版)李普曼 等著 pdf 1/3

     小结 23  术语表 23  第Ⅰ部分 C++基础 27  第2章 变量和基本类型 29  2.1 基本内置类型 30  2.1.1 算术类型 30  2.1.2 类型转换 32  2.1.3 字面值常量 35  2.2 变量 38  2.2.1 变量定义 38  2.2.2 变量...

    C++ 标准库

    #### 七、小结 C++标准库中的容器为开发者提供了强大而灵活的数据结构支持,使得程序设计变得更加简单高效。通过选择合适的容器,可以有效地提高程序的性能和可维护性。在实际开发中,开发者应根据具体需求选择最...

    ProC-C++编程指南目录

    #### 1.4 小结 - 概括本章要点,为读者提供清晰的学习路径和理解框架。 ### 二、Pro*C/C++在不同编译环境下的应用 #### 2.1 Pro*C/C++与Visual C++ - 介绍Pro*C/C++如何集成到Visual C++环境中,包括工具的配置和...

    C++ STL开发技术导引(第5章)

    1.12 本章小结 23 第2章 C++模板技术 25 2.1 函数模板 25 2.2 类模板 27 2.3 模板完全特化 28 2.4 函数模板重载 30 2.5 类模板继承 30 2.6 本章小结 31 第3章 C++ I/O流技术 32 3.1 I/O流类 32 ...

    C++ STL开发技术导引(第3章)

    1.12 本章小结 23 第2章 C++模板技术 25 2.1 函数模板 25 2.2 类模板 27 2.3 模板完全特化 28 2.4 函数模板重载 30 2.5 类模板继承 30 2.6 本章小结 31 第3章 C++ I/O流技术 32 3.1 I/O流类 32 ...

    C++入门经典第三版pdf

    ### 小结 《C++入门经典第三版》这本书通过详细的讲解和丰富的示例,非常适合C++初学者阅读。从基础语法到面向对象编程,再到高级特性,本书都进行了全面而深入的探讨。无论是想成为一名优秀的软件工程师还是对...

    C++Primer(第5版 )中文版(美)李普曼等著.part2.rar

     小结 23  术语表 23  第Ⅰ部分 C++基础 27  第2章 变量和基本类型 29  2.1 基本内置类型 30  2.1.1 算术类型 30  2.1.2 类型转换 32  2.1.3 字面值常量 35  2.2 变量 38  2.2.1 变量定义 38  2.2.2 变量...

    C++第11版本中的一些强大的新特性小结

    在C++第11版本中,引入了许多强大的新特性,极大地提升了编程的效率和代码的可读性。这里我们将详细探讨几个重要的特性:自动类型推导(Auto Type Deduction)、强类型枚举(Strongly Typed Enums)、Lambda表达式、...

    C++大学教程,一本适合初学者的入门教材(part2)

    小结 术语 自测练习 自测练习答案 练习 第2章 控制结构 2.1 简介 2.2 算法 2.3 伪代码 2.4 控制结构 2.5 if选择结构 2.6 if/e1se选择结构 2.7 while重复结构 2.8 构造算法:实例研究1(计数器控制重复) 2.9 ...

    C++大学教程,一本适合初学者的入门教材(part1)

    小结 术语 自测练习 自测练习答案 练习 第2章 控制结构 2.1 简介 2.2 算法 2.3 伪代码 2.4 控制结构 2.5 if选择结构 2.6 if/e1se选择结构 2.7 while重复结构 2.8 构造算法:实例研究1(计数器控制重复) 2.9 ...

    标准库容器小结.pdf

    map和multimap将值关联到键上,同样维护元素的唯一性,map要求键的唯一性,而multimap允许键重复。 无序关联容器,如unordered_map和unordered_multimap,基于哈希表实现,使得查找、插入和删除操作的平均复杂度为O...

    集合小结 Collection

    ### 集合小结 Collection #### Java集合概述 Java中的集合是一组对象的组合,类似于C++标准模板库中的容器。但是与C++不同的是,Java集合不仅可以存储单一类型的数据,还可以存储不同类型的对象。这使得Java集合...

    C++中const用法小结

    - 在容器类如`std::vector`或`std::map`中,`const_iterator`用于遍历容器的元素而不修改它们。 9. **const参数** - 函数参数可以声明为`const`,确保该函数不会修改传递的参数值。 通过正确使用`const`,程序员...

Global site tag (gtag.js) - Google Analytics