C++ map 常用部分

文章目录

    • 定义及初始化
    • 一些基本操作
    • 插入
    • 查找
    • 删除
    • 遍历

定义及初始化

#include <map>map<string, int> m1;
m1['first']=7;map<string,int> m2 = {{"first",1}, {"sec",2}, {"trd",3}
};map<string, int> m3;
m3.insert({ "abc", 1 });    //最常用,使用这种就可以了
m3.insert(make_pair(string("def"), 2));
m3.insert(pair<string, int>(string("ghi"), 3));

一些基本操作

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的函数

插入

用insert函数插入数据,在数据的插入上涉及到集合的唯一性这个概念,即当map中有这个关键字时,insert操作是无法插入数据的,但是用数组方式插入相同键的键值对时,后一组的键值对会覆盖前一组键值对。

map<int,string> m;
//方法一
m.insert(pair<int ,string>(1,"stu1"));
//方法二
m[2] = "stu2";
//方法三
m.insert(make_pair(3,"teacher03"));//无需写出型别,就可以生成一个pair对象,更方便
//方法四
m.insert(map<int,string>::value_type(5,"stu5"));
m.insert({5,"stu5"});

还可以参考:https://blog.csdn.net/tjcwt2011/article/details/136475689

查找

if(m.find(1) != m.end())cout << "FOUND" << endl;	
elsecout << "NOTFOUND" << endl; for(auto iter = m.begin(); iter != m.end();)
{if (iter->first == 4){cout<<"FOUND";}else++iter;
}

删除

//方法一
m.erase(2);
//方法二
auto it =  m.find(3);
m.erase(it);//像这种删除单个节点,map的行为不会出现问题,但是当在一个循环里用的时候,往往会被误用。//错误用法:
for(ITER iter=mapTest.begin();iter!=mapTest.end();++iter)  
{  cout<<iter->first<<":"<<iter->second<<endl;  mapTest.erase(iter);  
}  //这是一种错误的写法,会导致程序行为不可知,原因是map是关联容器,对于关联容器来说,如果一个元素已经被删除,那么其对应的迭代器就失效了,不应该再被使用,负责会导致程序无定义的行为。//正确用法一
std::map<std::string, std::string >::iterator it = mapTest.begin();  
while(it != mapTest.end())  
{  if(TestVal(it->second))  {  it = mapTest.erase(it);  }  else  it++;  
}  //正确用法二
for(ITER iter=mapTest.begin();iter!=mapTest.end();) //注意此处不能再写iter++  
{  cout<<iter->first<<":"<<iter->second<<endl;  mapTest.erase(iter++);  
}  
//在这种用法中,该方法中利用了后++的特点,这个时候执行mapTest.erase(it++);这条语句分为三个过程
//1、先把it的值赋值给一个临时变量做为传递给erase的参数变量
//2、因为参数处理优先于函数调用,所以接下来执行了it++操作,也就是it现在已经指向了下一个地址。
//3、再调用erase函数,释放掉第一步中保存的要删除的it的值的临时变量所指的位置。

Reference:https://www.cnblogs.com/pannyvan/p/6233400.html

遍历

//使用迭代器遍历
for(auto it = m.begin(); it != m.end(); it++ )
{cout << it->first <<" " << it->second << endl;
} //c++11之后
for(auto it : m){cout << it.first <<" "<< it.second <<endl;
}

Reference:

https://blog.csdn.net/qq_48508278/article/details/118531197

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/787568.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GPT-5:更强的ChatGPT!将在高级推理功能上实现重大进步!GPT-5有哪些功能作用?

自 Claude 3 发布以来&#xff0c;外界对 GPT-5 的期待越来越强。毕竟Claude 3已经全面超越了 GPT-4&#xff0c;成为迄今为止最强大模型。 对于即将发布的GPT-5&#xff0c;有哪些期待&#xff1f; 目前来说&#xff0c;GPT-5的将具备哪些新能力&#xff1f; GPT-5性能进步…

C语言求解最大公约数(欧几里得算法的应用)

今天我们来看看两个数的最大公约数怎么求&#xff0c;话不多说之间开干&#xff01; 代码1&#xff08;呆呆的暴力求解&#xff09; #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> int main() {int x, y;printf("请输入两个正整数&#xff1a;>");sc…

Python是解释型语言,为啥还有 __pycache__ 文件呢?为啥还有.pyc 文件呢?

你好&#xff0c;我是 shengjk1&#xff0c;多年大厂经验&#xff0c;努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注&#xff01;你会有如下收益&#xff1a; 了解大厂经验拥有和大厂相匹配的技术等 希望看什么&#xff0c;评论或者私信告诉我&#xff01; 文章目录 …

【算法集训】基础算法:双指针

344. 反转字符串 // 双指针思路 void reverseString(char* s, int sSize) {int i 0,j sSize - 1;while(i < j) {char tmp s[i];s[i] s[j];s[j] tmp;i , j --;} }392. 判断子序列 // 双指针 bool isSubsequence(char* s, char* t) {// 定义s和t的下标指针int i 0, j …

使用Java流API构建树形结构数据

简介&#xff1a; 在实际开发中&#xff0c;构建树状层次结构是常见需求&#xff0c;如组织架构、目录结构或菜单系统。本教案通过解析给定的Java代码&#xff0c;展示如何使用Java 8 Stream API将扁平化的菜单数据转换为具有层级关系的树形结构。 1. 核心类定义 - Menu Data…

【图论】【拓扑排序】1857. 有向图中最大颜色值

本文涉及的知识点 图论 拓扑排序 LeetCode1857. 有向图中最大颜色值 给你一个 有向图 &#xff0c;它含有 n 个节点和 m 条边。节点编号从 0 到 n - 1 。 给你一个字符串 colors &#xff0c;其中 colors[i] 是小写英文字母&#xff0c;表示图中第 i 个节点的 颜色 &#xf…

MySQL进阶-----SQL提示与覆盖索引

目录 前言 一、SQL提示 1.数据准备 2. SQL的自我选择 3.SQL提示 二、覆盖索引 前言 MySQL进阶篇的索引部分基本上要结束了&#xff0c;这里就剩下SQL提示、覆盖索引、前缀索引以及单例联合索引的内容。那本期的话我们就先讲解SQL提示和覆盖索引先&#xff0c;剩下的内容就…

ES6+对象常用方法

1.往Object里面添加元素 const obj {timeArr: [],fileIds: [],isVerifyOrder: res?.isVerifyOrder ? "true" : "false",isCompose: res?.isCompose ? "true" : "false",};Object.assign(res, obj);//往res添加属性const obj Ob…

HDU1020--编码问题

试题描述 问题详情如下图所示&#xff1a;要求&#xff1a;java实现、数据结构知识 参考代码 比较垃圾&#xff0c;在别人基础上改的&#xff0c;懒得重构&#xff0c;&#xff0c;&#xff0c;仅供参考 import java.util.Scanner;public class HDU1020StringEncoding {pu…

虚拟机安装银河麒麟

背景 由于Centos将于2024-06-30结束维护【脱保】&#xff0c;届时会存在Bug无人修复及功能无人开发等问题&#xff0c;所以要赶在这个节点前完成操作系统升级。可选的就是RedHat、Ubuntu以及国产信创【中标麒麟、银河麒麟、统信等】&#xff0c;或者使用云上操作系统【例如租阿…

40V耐压5A同步整流DCDC降压恒压芯片 高效率 外围小

同步整流恒压芯片是一种电源管理芯片&#xff0c;它能够在不同电压输入条件下保持输出电压恒定。这种芯片广泛应用于各种电子设备中&#xff0c;如通讯设备、液晶显示器、上网本、机顶盒等。 同步整流恒压芯片的工作原理是利用开关稳压器在输入电压和输出电压之间进行能量传递&…

GraphQL入门教程:构建更高效的APIs

GraphQL入门教程&#xff1a;构建更高效的APIs GraphQL是一个用于API的查询语言&#xff0c;由Facebook于2015年公开发布。它允许客户端精确地指定它们需要从API获取哪些数据&#xff0c;从而使数据交换更加高效和强大。与传统的REST API相比&#xff0c;GraphQL提供了更加灵活…

问答系统开发:基于深度学习的文本理解与生成

目录 1.前言 2.问答系统架构与流程 2.2.架构概述 2.3.流程描述 3.使用Transformer模型处理问答任务 3.1.BERT在问答任务中的应用 4.实现简单的交互式问答系统 5.总结 1.前言 本文旨在详细介绍问答系统的架构与流程&#xff0c;以及如何利用Transformer模型&#xff08;…

【笔记】通过码云Gitee获取OpenHarmony源码

Note&#xff1a;下面包含操作过程和问题解决&#xff08;首次安装Ubuntu&#xff0c;环境未完善&#xff09;&#xff0c;没有遇到问题可以直接跳过问题part了&#xff0c;小白也能完成配置下载。 前置准备&#xff08;Git环境账号&#xff09; &#xff08;一&#xff09;安…

做抖店没有产品货源?怎么玩?筛选货源的方法你需要了解清楚!

大家好&#xff0c;我是电商小布。 有很多的新手朋友们在玩抖店的时候&#xff0c;遇到的第一个问题就是自己手里没有产品在。 没有产品货源&#xff0c;也就没办法上架店铺&#xff0c;更别提交易工作了。 那么在这种情况下&#xff0c;该怎么来玩呢&#xff1f; 既然我们…

抖音降权限流后怎么办?可以考虑这样自查!

在抖音运营过程中&#xff0c;可能会遇到账号被降权限流的情况。面对这种情况&#xff0c;我们可以从以下几个方面进行自查&#xff0c;以找出问题所在并采取相应措施。 1 账号安全检查 包括敏感操作自查和违规操作检查。在敏感操作自查方面&#xff0c;需要回顾账号的历史操…

设计模式——行为型——责任链模式Chain Of Responsibility

请求类 public class ApproverRequest {private int type;//请求批准的类型private float price;//请求的金额private int id;//请求的编号 } 审批人抽象类 public abstract class ApproverPerson {protected ApproverPerson next;protected String name;//审批过程public a…

Debian/Ubuntu安装ping和netstat命令

sudo apt-get install net-tools#如果需要ping的话&#xff0c;安装如下软件 sudo apt-get install iputils-ping Debian/Ubuntu无netstat命令解决方案 Messay

python基础知识5——时间的处理和转换

python程序能用很多方式处理日期和时间&#xff0c;转换日期格式是一个常见的功能。 1、time模块 1.1、获取当前时间戳(unix时间戳)import time tick time.time() print(tick)1.2、# 获取时间元组import time t time.localtime() # 可传入unix时间戳进行转换 print(t)1.3、…

跨境运营必看:TikTok账号防封指南

多人在使用TikTok的过程中都会遇到一些问题&#xff0c;比如为什么TikTok没有浏览量&#xff1f;事实上&#xff0c;这很可能是因为你的账号已被禁止。但为什么它会被封呢&#xff1f;你怎样才能解决它&#xff1f; 一、TikTok账号为什么被封&#xff1f; 1、什么是 TikTok 影…