Multimap的用法詳解 VSSW • 2024-10-11 11:41 • 編程一、基本介紹Multimap是C++標準庫中的容器之一,是一種關聯式容器,其中動態存儲數據,並能夠根據鍵值對數據進行快速訪問。與普通的Map不同的是,Multimap中可以同時存在相同的鍵值。Multimap使用二叉搜索樹實現,比較的依據是鍵值對的比較結果。一個Multimap包含了很多鍵值對,其中每一個鍵值對可以看作是一個節點。可以使用關鍵字來查找值。關鍵字可以有重複值,也就是說多個鍵值對可以有相同的關鍵字。值可以被修改,但是鍵不會被修改。Multimap模板定義在頭文件中。 #include <iostream> #include <map> int main() { std::multimap mymm; mymm.insert(std::pair('x',10)); mymm.insert(std::pair('y',20)); mymm.insert(std::pair('z',30)); mymm.insert(std::pair('z',40)); mymm.insert(std::pair('z',50)); std::cout << "mymm contains:\n"; for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 二、插入元素Multimap支持兩種插入元素的方式——insert和emplace。其中,insert接受一個鍵值對作為參數,如果Multimap中已經存在相同的鍵,則插入新值,如果不存在,則插入整個鍵值對。emplace則直接接受鍵和值,然後在Multimap中進行排序並插入。除了上述兩種方法,Multimap還可以通過直接訪問其迭代器來進行插入操作。使用insert進行插入操作: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.insert(std::pair<char,int>('a',10)); mymm.insert(std::pair<char,int>('b',20)); mymm.insert(std::pair<char,int>('c',30)); for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 使用emplace進行插入操作: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 使用迭代器進行插入操作: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; auto it = mymm.emplace('a',10); mymm.emplace_hint(it,'b',20); mymm.emplace_hint(mymm.end(),'c',30); for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 三、查找元素Multimap支持多種查找元素的方式,其中find、count、equal_range和lower_bound是比較常用的。其中,find接受一個鍵,返回Multimap中指向對應元素的迭代器。如果Multimap中不存在該鍵,則返回Multimap的end迭代器。count接受一個鍵,返回Multimap中該鍵對應元素的個數。equal_range則返回一個pair對象,其中first是指向Multimap中首個匹配元素的迭代器,second是指向Multimap中最後一個匹配元素之後的迭代器。lower_bound也返回與當前鍵匹配的第一個元素的迭代器。使用find查找元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); auto it = mymm.find('b'); std::cout << "Key found: " << it->first << " = " << it->second << '\n'; return 0; } 使用count查找元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); int count = mymm.count('b'); std::cout << "Number of values with key 'b': " << count << '\n'; return 0; } 使用equal_range查找元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); auto range = mymm.equal_range('b'); for (auto it = range.first; it != range.second; it++) std::cout << it->first << " => " << it->second << '\n'; return 0; } 使用lower_bound查找元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); auto it = mymm.lower_bound('b'); std::cout << "Key found: " << it->first << " = " << it->second << '\n'; return 0; } 四、刪除元素與插入元素類似,Multimap支持多種刪除元素的方式,其中erase接受一個元素的迭代器,刪除對應的元素。remove則接受一個鍵,刪除該鍵對應的所有元素。使用erase刪除元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); auto it = mymm.find('b'); mymm.erase(it); for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 使用remove刪除元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); mymm.emplace('b',40); mymm.erase('b'); for (auto elem : mymm) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 五、其他操作Multimap支持許多其他的操作,包括size(返回Multimap中元素的數量)、empty(如果Multimap為空則返回true)、swap(交換兩個Multimap中的元素)、clear(清除Multimap中的所有元素)等。使用size獲取Multimap中元素數量: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); std::cout << "The size of the Multimap is " << mymm.size() << '\n'; return 0; } 使用empty判斷Multimap是否為空: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; std::cout << "The Multimap is " << (mymm.empty() ? "empty" : "not empty") << '\n'; return 0; } 使用swap交換兩個Multimap中的元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm1; std::multimap<char,int> mymm2; mymm1.emplace('a',10); mymm1.emplace('b',20); mymm1.emplace('c',30); mymm2.emplace('x',40); mymm2.emplace('y',50); mymm1.swap(mymm2); for (auto elem : mymm2) std::cout << elem.first << " => " << elem.second << '\n'; return 0; } 使用clear清除Multimap中的所有元素: #include <iostream> #include <map> int main() { std::multimap<char,int> mymm; mymm.emplace('a',10); mymm.emplace('b',20); mymm.emplace('c',30); mymm.clear(); std::cout << "The Multimap is " << (mymm.empty() ? "empty" : "not empty") << '\n'; return 0; } 原創文章,作者:VSSW,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/142409.htmlMultimap詳解 贊 (0) 打賞 微信掃一掃 支付寶掃一掃 VSSW 0 0 生成海報 ios支持jsp么,ios打開jsp 上一篇 2024-10-11 11:41 Sql正則表達式全面解析 下一篇 2024-10-11 11:41相關推薦 Linux sync詳解 一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁碟中。在執行sync之前,所有的文件系統更新將不會立即寫入磁碟,而是先緩存在內存… BPORF 編程 2025-04-25 神經網路代碼詳解 神經網路作為一種人工智慧技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網路的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網路模型編寫的代碼技術。 一、神經網… XNBEQ 編程 2025-04-25 Java BigDecimal 精度詳解 一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci… EPJFU 編程 2025-04-25 Python輸入輸出詳解 一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件… LEJKS 編程 2025-04-25 Python安裝OS庫詳解 一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變數讀取等系統級操作。 OS庫中包含了大量的文件和目… QOCNF 編程 2025-04-25 git config user.name的詳解 一、為什麼要使用git config user.name? git是一個非常流行的分散式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi… SGKGI 編程 2025-04-25 nginx與apache應用開發詳解 一、概述 nginx和apache都是常見的web伺服器。nginx是一個高性能的反向代理web伺服器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web… TFXRP 編程 2025-04-25 MPU6050工作原理詳解 一、什麼是MPU6050 MPU6050是一種六軸慣性感測器,能夠同時測量加速度和角速度。它由三個感測器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其… AINVH 編程 2025-04-25 詳解eclipse設置 一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇… QWCOK 編程 2025-04-25 Linux修改文件名命令詳解 在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命… HCOQE 編程 2025-04-25 發表回復 請登錄後評論...登錄後才能評論 提交