C++——map注意事项
1. C++标准模块库STL中提供了两种基本的关联容器:set和map。其内部实现是都是采用红黑树,但不同的是,set中结点存储的是键值,map中结点存储的是<key,value>的键值对。在map中,由key查找value时,首先要判断map中是否包含key。如果不检查,直接返回map[key],可能会出现意想不到的行为。
2. 如果map包含key,则map[key]返回key所对应value的引用;如果map不包含key,使用下标有一个危险的副作用,会在map中插入一个key的元素,value取默认值,并返回value的引用,这就是为什么当向map中插入一个元素时,map[key] = value是成立的。综上所述,map[key]总有返回值。
3. map提供了两种方式,查看是否包含key,即使用成员函数count和find,对于map<Type1,Type2> m:
- m.count(key):由于map不包含重复的key,因此m.count(key)取值为0,或者1,表示是否包含。
 - m.find(key):返回迭代器,判断是否存在。若存在则返回key对应结点的迭代器,否则返回m.end()
 
4. 对于查找map中是否存在key,有下面两种写法:
使用成员函数count:
bool is_map_key_exist1(const map<int,int> &m, const int &key)
{
if(m.count(key) > )
return true;
return false;
}
使用成员函数find:
bool is_map_key_exist2(const map<int,int> &m, const int &key)
{
if(m.find(key) != m.end())
return true;
return false;
}
5. 当需要进行赋值或查找key对应的值时,推荐使用find。
例如:
//map<int,int> m;
//int key;
auto it = m.find(key);
if( it != m.end())
return it->second;
可以看到只进行了一次查找。
若先使用count判断是否存在,再使用[]返回value,即:
//map<int,int> m;
//int key;
if(m.count(key) > )
return m[key];
可以看到count和[]分别进行了一次查找,即两次查找。
基于效率的考虑,我们推荐使用find。
6. 对于STL中的容器,除了使用成员函数find返回迭代器外,还有泛型算法find(begin,end,target)查找目标。
参考资料:
- https://www.cnblogs.com/nzbbody/p/3409298.html
 
C++——map注意事项的更多相关文章
- java8使用stream的collect进行list转map注意事项
		
1.创建Person类 package com.xkzhangsan.normal.collectors; public class Person { private Integer id; priv ...
 - C++ map注意事项
		
1.在map中,由key查找value时,首先要判断map中是否包含key. 2.如果不检查,直接返回map[key],可能会出现意想不到的行为.如果map包含key,没有问题,如果map不包含key ...
 - c++ map 注意事项
		
1. 往map里面插入元素: 下标方式[]: map[key] = value; 调用insert: map.insert(make_pair(key, value)); 下标方式 ...
 - gson 转换 List<Map> 注意事项
		
如果list泛型显示指定Map类型, 这时的Map 不能直接转换为 jre自带的 map类型 gson封装了 StringMap 进行转换
 - HashMap的使用方法及注意事项
		
99.Map(映射):Map 的keySet()方法会返回 key 的集合,因为 Map 的键是不能重复的,因此 keySet()方法的返回类型是 Set:而 Map 的值是可以重复的,因此 valu ...
 - Golang 数组、切片、映射
		
定义数组 var arr1 [5]int //整型类型 fmt.Println(arr1) //[0 0 0 0 0] //赋值 arr1 = [5]int{1, 2, 3, 4, 5} fmt.Pr ...
 - 小程序-地图API
		
摘要 地图组件-map 注意事项&&Bug: 1.map 组件是由客服端创建的原生组件,它的层级是最高的. 2.请勿在scroll-view中使用map组件 3.css动画对map组件 ...
 - slice使用了解
		
切片 什么是slice slice的创建使用 slice使用的一点规范 slice和数组的区别 slice的append是如何发生的 复制Slice和Map注意事项 什么是slice Go中的切片,是 ...
 - Map,List,POJO深拷贝(序列化实现)方法与注意事项
		
转载请注明出处,谢谢! 方法1: /*jdk >= 1.5*/ @SuppressWarnings("unchecked") public static <T> ...
 
随机推荐
- 【开发工具IDE】eclipse的web项目的tomcat安装部署问题
			
一.发现问题 在eclipse中新建Dynamic Web Project,配置好本地的tomcat并写好代码后选择Run on Server,但运行后发现在tomcat的安装目录下的webapps并 ...
 - Guardian of Decency UVALive - 3415(最大独立集板题)
			
老师在选择一些学生做活动时,为避免学生发生暧昧关系,就提出了四个要求.在他眼中,只要任意两个人符合这四个要求之一,就不可能发生暧昧.现在给出n个学生关于这四个要求的信息,求老师可以挑选出的最大学生数量 ...
 - [codeforces696B]Puzzles
			
B. Puzzles time limit per test 1 second memory limit per test 256 megabytes input standard input ou ...
 - Day21-获取用户请求相关信息及请求头
			
1. request里面还包含请求头等信息,可以打印看一下. views.py中的程序 from django.shortcuts import render,HttpResponse from dj ...
 - EVE-NG FAQ
			
EVE-NG FAQ How to install EVE on bare box using Ubuntuoriginal ISO distro. Get Ubuntu ISO: https://w ...
 - Docker学习笔记六:Docker搭建企业级私有仓库
			
前言 Docker不仅是一个强大的服务器部署工具,而且它还有一个官方的Docker Hub registry用于储存Docker镜像.上传镜像到Docker Hub是免费的,上传的镜像文件同时也对公共 ...
 - 【Cogs2187】帕秋莉的超级多项式(多项式运算)
			
[Cogs2187]帕秋莉的超级多项式(多项式运算) 题面 Cogs 题解 多项式运算模板题 只提供代码了.. #include<iostream> #include<cstdio& ...
 - 三年java面试题
			
前言: 楼主毕业三年,从大学时期就开始一直从事java web方面的开发.我在去年的今天有一篇帖子:两年java面试经验.经历了一年的上班,成长了很多.今年因为某些原因辞职了.从2月底辞职,到3月初, ...
 - mysql四-2:多表查询
			
一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 准备表 #建表 create table department( id int, name varchar(20) ); create ta ...
 - 洛谷P2344 奶牛抗议
			
题目背景 Generic Cow Protests, 2011 Feb 题目描述 约翰家的N 头奶牛正在排队游行抗议.一些奶牛情绪激动,约翰测算下来,排在第i 位的奶牛的理智度为Ai,数字可正可负. ...