C++ map multimap 容器:賦值、排序、大小與刪除操作

概述

mapmultimap是C++ STL中的關聯容器,它們存儲的是鍵值對(key-value pairs),并且會根據鍵(key)自動排序。兩者的主要區別在于:

  • map不允許重復的鍵
  • multimap允許重復的鍵

本文將詳細解析示例代碼中涉及的map操作,包括賦值排序大小查詢刪除等核心功能。

1. 頭文件與命名空間

#include <iostream>
#include <map>using namespace std;
  • #include <map>:必須包含的頭文件,提供mapmultimap的實現
  • using namespace std:使用標準命名空間,避免每次都要寫std::

2. 自定義排序規則(仿函數)

class CompareInt {
public:bool operator()(const int& left, const int& right) const {return left > right;  // 降序排序}
};
  • 仿函數(Functor):重載了()運算符的類,可以像函數一樣調用
  • 這里實現了降序排序規則,當left > right時返回true
  • 注意operator()應該聲明為const,因為它不修改對象狀態

3. map的聲明與初始化

map<int, string> mapStu;  // 默認less 升序排序
//map<int, string,greater<int>> mapStu;  // greater 降序排序
//map<int, string,CompareInt> mapStu;  // 使用自定義仿函數
  • 默認排序:不指定第三個模板參數時,使用less<Key>,即升序排序
  • 內置排序規則:可以使用greater<Key>實現降序排序
  • 自定義排序:通過傳遞自定義的仿函數類型作為第三個模板參數

4. 插入元素

mapStu.insert(pair<int, string>(2, "小明"));
mapStu.insert(pair<int, string>(3, "廉頗"));
mapStu.insert(pair<int, string>(1, "妲己"));
mapStu.insert(pair<int, string>(4, "莊周"));
  • insert():插入鍵值對
  • 使用pair構造鍵值對,first是鍵,second是值
  • 插入后元素會根據鍵自動排序

5. 拷貝構造與賦值

map<int, string> mapB(mapStu);   // 拷貝構造
map<int, string> mapC = mapStu;  // 賦值操作
  • 拷貝構造:創建一個新map并復制所有元素
  • 賦值操作:將已有map的所有元素復制到另一個map
  • 兩種方式都會創建與原map完全相同的新容器

6. 元素訪問與修改

mapC[3] = "小喬";  // 通過鍵訪問并修改值
  • operator[]:通過鍵訪問對應的值
  • 如果鍵不存在,會自動插入該鍵,值為默認構造

7. 交換操作

mapC.swap(mapB);  // 交換兩個map的內容
  • swap():高效交換兩個map的內容
  • 實際只交換內部指針,不復制元素,時間復雜度O(1)

8. 刪除操作

8.1 刪除區間元素
map<int, string>::iterator iBegin = mapB.begin();
++iBegin;
map<int, string>::iterator iEnd = mapB.end();
mapB.erase(iBegin, iEnd);  // 刪除[iBegin, iEnd)區間
  • erase(beg, end):刪除迭代器區間[beg, end)內的元素
  • 區間是半閉半開的,包含beg但不包含end
  • 返回void(新標準返回下一個元素的迭代器)
8.2 刪除單個元素
mapC.erase(mapC.begin());  // 刪除第一個元素
mapC.erase(4);             // 刪除鍵為4的元素
  • erase(pos):刪除迭代器pos指向的元素
  • erase(key):刪除所有鍵等于key的元素(對于map最多一個)
8.3 清空容器
mapC.clear();  // 清空所有元素
  • clear():刪除容器中的所有元素,使size為0
8.4 刪除結果檢查
map<int, string, greater<int>>::size_type st = mapStu.erase(5);
cout << "st = " << st << endl;  // 輸出刪除的元素個數
  • **erase(key)**返回刪除的元素個數
  • 對于map,返回值只能是0或1
  • 對于multimap,返回值可以是任意非負整數

9. 大小查詢

if (!mapC.empty()) {cout << "mapC的大小: " << mapC.size() << endl;
}
  • empty():檢查容器是否為空
  • size():返回容器中元素的個數
  • 通常先檢查empty()再調用size()更安全

10. 迭代器遍歷

for (map<int, string, CompareInt>::iterator it = mapStu.begin(); it != mapStu.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;
}
  • begin()/end():獲取首元素和尾后迭代器
  • 迭代器解引用得到pair<const Key, Value>
  • 可以用it->firstit->second訪問鍵和值

完整代碼回顧

#include <iostream>
#include <map>using namespace std;// 仿函數用于比較int(降序排序)
class CompareInt {
public:bool operator()(const int& left, const int& right) const {return left > right;    // 降序排序}
};int main(void) {map<int, string> mapStu;  // 默認less 升序排序//map<int, string,greater<int>> mapStu;  // greater 降序排序// 使用自定義的仿函數作為比較器//map<int, string,CompareInt> mapStu;  mapStu.insert(pair<int, string>(2, "小明"));mapStu.insert(pair<int, string>(3, "廉頗"));mapStu.insert(pair<int, string>(1, "妲己"));mapStu.insert(pair<int, string>(4, "莊周"));// map對象的拷貝構造與賦值map<int, string> mapB(mapStu);   // 拷貝構造for (map<int, string>::iterator it = mapB.begin(); it != mapB.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}cout << endl;map<int, string> mapC = mapStu;  // 賦值for (map<int, string>::iterator it = mapC.begin(); it != mapC.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}cout << endl;mapC[3] = "小喬";mapC.swap(mapB);// map的刪除map<int, string>::iterator iBegin = mapB.begin();++iBegin;map<int, string>::iterator iEnd = mapB.end();mapB.erase(iBegin, iEnd);  // 刪除區間mapC.erase(mapC.begin());  // 刪除第一個元素mapC.erase(4);             // 刪除key為4的元素mapC.clear();              // 清空容器map<int, string, greater<int>>::size_type st = mapStu.erase(5);cout << "st = " << st << endl;  // 輸出刪除個數// map的大小if (!mapC.empty()) {cout << "mapC的大小: " << mapC.size() << endl;}// 遍歷mapfor (map<int, string, CompareInt>::iterator it = mapStu.begin(); it != mapStu.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}system("pause");return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/80454.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/80454.shtml
英文地址,請注明出處:http://en.pswp.cn/web/80454.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

AI Agent開發第70課-徹底消除RAG知識庫幻覺(4)-解決知識庫問答時語料“總重復”問題

開篇 “解決知識庫幻覺”系列還在繼續,這是因為:如果只是個人玩玩,像自媒體那些說的什么2小時搭一個知識庫+deepseek不要太香一類的RAG或者是基于知識庫的應用肯定是沒法用在企業級落地上的。 我們真的經歷過或者正在經歷的人都是知道的,怎么可能2小時就搭建完成一個知識…

【DAY22】 復習日

內容來自浙大疏錦行python打卡訓練營 浙大疏錦行 仔細回顧一下之前21天的內容 作業&#xff1a; 自行學習參考如何使用kaggle平臺&#xff0c;寫下使用注意點&#xff0c;并對下述比賽提交代碼 kaggle泰坦里克號人員生還預測

【Docker】Docker Compose方式搭建分布式協調服務(Zookeeper)集群

開發分布式應用時,往往需要高度可靠的分布式協調,Apache ZooKeeper 致力于開發和維護開源服務器&#xff0c;以實現高度可靠的分布式協調。具體內容見zookeeper官網。現代應用往往使用云原生技術進行搭建,如何用Docker搭建Zookeeper集群,這里介紹使用Docker Compose方式搭建分布…

若依框架Consul微服務版本

1、最近使用若依前后端分離框架改造為Consul微服務版本 在這里分享出來供大家參考 # Consul微服務配置參數已經放置/bin/Consul微服務配置目錄 倉庫地址&#xff1a; gitee&#xff1a;https://gitee.com/zlxls/Ruoyi-Consul-Cloud.git gitcode&#xff1a;https://gitcode.c…

BOM知識點

BOM&#xff08;Browser Object Model&#xff09;即瀏覽器對象模型&#xff0c;是用于訪問和操作瀏覽器窗口的編程接口。以下是一些BOM的知識點總結&#xff1a; 核心對象 ? window&#xff1a;BOM的核心對象&#xff0c;代表瀏覽器窗口。它也是全局對象&#xff0c;所有全…

什么是遷移學習(Transfer Learning)?

什么是遷移學習&#xff08;Transfer Learning&#xff09;&#xff1f; 一句話概括 遷移學習研究如何把一個源領域&#xff08;source domain&#xff09;/源任務&#xff08;source task&#xff09;中獲得的知識遷移到目標領域&#xff08;target domain&#xff09;/目標任…

[創業之路-362]:企業戰略管理案例分析-3-戰略制定-華為使命、愿景、價值觀的演變過程

一、華為使命、愿景、價值觀的演變過程 1、創業初期&#xff08;1987 - 1994 年&#xff09;&#xff1a;生存導向&#xff0c;文化萌芽 使命愿景雛形&#xff1a;1994年華為提出“10年之后&#xff0c;世界通信行業三分天下&#xff0c;華為將占一份”的宏偉夢想&#xff0c…

Python黑魔法與底層原理揭秘:突破語言邊界的深度探索

Python黑魔法與底層原理揭秘&#xff1a;突破語言邊界的深度探索 開篇&#xff1a;超越表面的Python Python常被稱為"膠水語言"&#xff0c;但其真正的威力在于對底層的高度可控性。本文將揭示那些鮮為人知的Python黑魔法&#xff0c;帶你深入CPython實現層面&…

Es的text和keyword類型以及如何修改類型

昨天同事觸發定時任務發現es相關服務報了一個序列化問題&#xff0c; 今天早上捕獲異常將異常堆棧全部打出來看&#xff0c;才發現是聚合的字段不是keyword類型的問題。 到kibbna命令行執行也是一樣的錯誤 使用 /_mapping查看索引的字段類型&#xff0c;才發現userUniqueid是te…

大語言模型 07 - 從0開始訓練GPT 0.25B參數量 - MiniMind 實機訓練 預訓練 監督微調

寫在前面 GPT&#xff08;Generative Pre-trained Transformer&#xff09;是目前最廣泛應用的大語言模型架構之一&#xff0c;其強大的自然語言理解與生成能力背后&#xff0c;是一個龐大而精細的訓練流程。本文將從宏觀到微觀&#xff0c;系統講解GPT的訓練過程&#xff0c;…

【Android】從Choreographer到UI渲染(二)

【Android】從Choreographer到UI渲染&#xff08;二&#xff09; Google 在 2012 年推出的 Project Butter&#xff08;黃油計劃&#xff09;是 Android 系統發展史上的重要里程碑&#xff0c;旨在解決長期存在的 UI 卡頓、響應延遲等問題&#xff0c;提升用戶體驗。 在 Androi…

mvc-ioc實現

IOC 1&#xff09;耦合/依賴 依賴&#xff0c;是誰離不開誰 就比如上訴的Controller層必須依賴于Service層&#xff0c;Service層依賴于Dao 在軟件系統中&#xff0c;層與層之間存在依賴。我們稱之為耦合 我們系統架構或者設計的一個原則是&#xff…

MATLAB安裝常見問題解決方案

目前新版本的matlab安裝往往需要十幾G的本地安裝容量&#xff0c;例如matlab2022b、matlab2023b, 首先就是要保證本地硬盤空間足夠大&#xff0c;如果沒有足夠的本地內存空間&#xff0c;那么可以嘗試釋放本地硬盤空間&#xff0c;或者安裝所需內存空間較小的舊版本的matlab&am…

程序代碼篇---python獲取http界面上按鈕或者數據輸入

文章目錄 前言 前言 本文簡單接受了python獲取http界面上按鈕或者數據輸入

深入理解 Cortex-M3 特殊寄存器

在上一篇文章中分享了 Cortex-M3 內核寄存器組的相關知識&#xff0c;實際上除了內核寄存器組外&#xff0c;CM3 處理器中還存在多個特殊寄存器&#xff0c;它們分別為 程序狀態寄存器&#xff0c;中斷/異常屏蔽寄存器 和 控制寄存器。 需要注意的是&#xff0c;特殊寄存器未經…

標準庫、HAl庫和LL庫(PC13初始化)

標準庫 (Standard Peripheral Library) c #include "stm32f10x.h"void GPIO_Init_PC13(void) {GPIO_InitTypeDef GPIO_InitStruct;RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);GPIO_InitStruct.GPIO_Pin GPIO_Pin_13;GPIO_InitStruct.GPIO_Mode GPIO_…

基于開源鏈動2+1模式AI智能名片S2B2C商城小程序的低集中度市場運營策略研究

摘要&#xff1a;本文聚焦于行業市場集中度問題&#xff0c;探討在低集中度市場中&#xff0c;如何利用開源鏈動21模式AI智能名片S2B2C商城小程序開展有效運營。分析了高集中度市場的競爭劣勢&#xff0c;闡述了開源鏈動21模式、AI智能名片以及S2B2C商城小程序的功能特點及其在…

一文讀懂-嵌入式Ubuntu平臺

現在直接在一些嵌入式Soc上移植ubuntu來用到產品上&#xff0c;剛開始感覺還挺臃腫的&#xff0c;后來細聊了下感覺還是有一定的優勢。 ubuntu相信大家在熟悉不過了&#xff0c;幾乎無處不在&#xff0c;小到咖啡機&#xff0c;大到火星車&#xff0c;為什么ubuntu如此廣泛&am…

箭頭函數及其與普通函數區別的詳細解釋

一、箭頭函數的基本特性 語法簡潔性 箭頭函數使用 > 符號定義&#xff0c;省略 function 關鍵字&#xff0c;適合快速定義匿名函數或簡單表達式。 // 普通函數 function sum(a, b) { return a b; } // 箭頭函數 const sum (a, b) > a b;若函數體為單行表達式&#x…

el-scrollbar 獲取滾動條高度 并將滾動條保持在低端

首先我們用ref綁定一個 scrollbar <el-scrollbar style"height: 100%;" ref"chatScrollRef" scroll"scrollTest">用scroll觸發滾動事件&#xff0c;一路滾到最底下&#xff0c;觀察三個屬性 const scrollTest ({scrollTop}) > {conso…