C++ 各種map對比

文章目錄

      • 特點比較
        • 1. `std::map`
        • 2. `std::unordered_map`
        • 3. `std::multimap`
        • 4. `std::unordered_multimap`
        • 5. `hash_map`(SGI STL 擴展)
      • C++ 示例代碼
      • 代碼解釋

特點比較

1. std::map
  • 底層實現:基于紅黑樹(一種自平衡的二叉搜索樹)。
  • 元素順序:元素按照鍵(key)的升序排列。
  • 鍵的唯一性:每個鍵只能出現一次,插入重復鍵的元素會被忽略。
  • 查找效率:查找操作的時間復雜度為 O ( l o g n ) O(log n) O(logn),其中 n n n 是容器中元素的數量。
  • 插入和刪除效率:插入和刪除操作的時間復雜度也為 O ( l o g n ) O(log n) O(logn)
2. std::unordered_map
  • 底層實現:基于哈希表。
  • 元素順序:元素沒有特定的順序,存儲位置由鍵的哈希值決定。
  • 鍵的唯一性:每個鍵只能出現一次,插入重復鍵的元素會覆蓋原有的元素。
  • 查找效率:平均情況下,查找操作的時間復雜度為 O ( 1 ) O(1) O(1),但在最壞情況下可能達到 O ( n ) O(n) O(n)
  • 插入和刪除效率:平均情況下,插入和刪除操作的時間復雜度為 O ( 1 ) O(1) O(1)
3. std::multimap
  • 底層實現:同樣基于紅黑樹。
  • 元素順序:元素按照鍵的升序排列。
  • 鍵的唯一性:允許鍵重復,即可以有多個元素具有相同的鍵。
  • 查找效率:查找操作的時間復雜度為 O ( l o g n ) O(log n) O(logn)
  • 插入和刪除效率:插入和刪除操作的時間復雜度為 O ( l o g n ) O(log n) O(logn)
4. std::unordered_multimap
  • 底層實現:基于哈希表。
  • 元素順序:元素沒有特定的順序,由鍵的哈希值決定存儲位置。
  • 鍵的唯一性:允許鍵重復。
  • 查找效率:平均情況下,查找操作的時間復雜度為 O ( 1 ) O(1) O(1),最壞情況下為 O ( n ) O(n) O(n)
  • 插入和刪除效率:平均情況下,插入和刪除操作的時間復雜度為 O ( 1 ) O(1) O(1)
5. hash_map(SGI STL 擴展)
  • 底層實現:基于哈希表。
  • 元素順序:元素沒有特定的順序,由鍵的哈希值決定存儲位置。
  • 鍵的唯一性:每個鍵只能出現一次,插入重復鍵的元素會覆蓋原有的元素。
  • 查找效率:平均情況下,查找操作的時間復雜度為 O ( 1 ) O(1) O(1),最壞情況下為 O ( n ) O(n) O(n)
  • 插入和刪除效率:平均情況下,插入和刪除操作的時間復雜度為 O ( 1 ) O(1) O(1)
    在早期的 C++ 標準(如 C++98、C++03)中有 hash_map,不過它并非標準庫的一部分,而是來自于 SGI STL 擴展。在 C++11 及以后的標準中,hash_mapstd::unordered_map 替代,std::unordered_map 成為標準的哈希表實現。不過有些編譯器仍然支持 hash_map,下面為你加入 hash_map 并進行比較,同時給出相應的 C++ 示例代碼。

C++ 示例代碼

#include <iostream>
#include <map>
#include <unordered_map>
#include <ext/hash_map>  // 對于支持 hash_map 的編譯器// 演示 std::map 的使用
void testStdMap() {std::map<int, std::string> myMap;myMap[1] = "apple";myMap[2] = "banana";myMap[1] = "cherry";  // 鍵 1 重復,會覆蓋原有的值std::cout << "std::map:" << std::endl;for (const auto& pair : myMap) {std::cout << pair.first << ": " << pair.second << std::endl;}
}// 演示 std::unordered_map 的使用
void testUnorderedMap() {std::unordered_map<int, std::string> myUnorderedMap;myUnorderedMap[1] = "apple";myUnorderedMap[2] = "banana";myUnorderedMap[1] = "cherry";  // 鍵 1 重復,會覆蓋原有的值std::cout << "\nstd::unordered_map:" << std::endl;for (const auto& pair : myUnorderedMap) {std::cout << pair.first << ": " << pair.second << std::endl;}
}// 演示 std::multimap 的使用
void testMultiMap() {std::multimap<int, std::string> myMultiMap;myMultiMap.insert({1, "apple"});myMultiMap.insert({2, "banana"});myMultiMap.insert({1, "cherry"});  // 鍵 1 重復,允許插入std::cout << "\nstd::multimap:" << std::endl;for (const auto& pair : myMultiMap) {std::cout << pair.first << ": " << pair.second << std::endl;}
}// 演示 std::unordered_multimap 的使用
void testUnorderedMultiMap() {std::unordered_multimap<int, std::string> myUnorderedMultiMap;myUnorderedMultiMap.insert({1, "apple"});myUnorderedMultiMap.insert({2, "banana"});myUnorderedMultiMap.insert({1, "cherry"});  // 鍵 1 重復,允許插入std::cout << "\nstd::unordered_multimap:" << std::endl;for (const auto& pair : myUnorderedMultiMap) {std::cout << pair.first << ": " << pair.second << std::endl;}
}// 演示 hash_map 的使用
void testHashMap() {__gnu_cxx::hash_map<int, std::string> myHashMap;myHashMap[1] = "apple";myHashMap[2] = "banana";myHashMap[1] = "cherry";  // 鍵 1 重復,會覆蓋原有的值std::cout << "\nhash_map:" << std::endl;for (const auto& pair : myHashMap) {std::cout << pair.first << ": " << pair.second << std::endl;}
}int main() {testStdMap();testUnorderedMap();testMultiMap();testUnorderedMultiMap();testHashMap();return 0;
}

代碼解釋

  • testStdMap 函數演示了 std::map 的使用,插入重復鍵的元素會覆蓋原有的值,元素按照鍵的升序排列。
  • testUnorderedMap 函數演示了 std::unordered_map 的使用,插入重復鍵的元素也會覆蓋原有的值,元素沒有特定的順序。
  • testMultiMap 函數演示了 std::multimap 的使用,允許插入重復鍵的元素,元素按照鍵的升序排列。
  • testUnorderedMultiMap 函數演示了 std::unordered_multimap 的使用,允許插入重復鍵的元素,元素沒有特定的順序。
  • testHashMap 函數演示了 hash_map 的使用,插入重復鍵的元素會覆蓋原有的值,元素沒有特定的順序。

需要注意的是,hash_map 不是標準 C++ 的一部分,如果你使用的編譯器不支持 ext/hash_map 頭文件,代碼可能無法編譯。建議優先使用標準的 std::unordered_map

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

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

相關文章

fontTools工具的使用介紹

前言 python工具庫fontTools&#xff0c;我是用來壓縮前端字體的&#xff0c;優化前端請求速度的&#xff1b;使用的過程中&#xff0c;遇到了不少的坑&#xff0c;把這個過程記錄下來&#xff0c;防止再犯。 安裝 # fontTools 4.56.0 pip install fontTools提取子字體集 方…

利用大語言模型生成的合成數據訓練YOLOv12:提升商業果園蘋果檢測的精度與效率

之前小編分享過關于《YOLO11-CBAM集成&#xff1a;提升商業蘋果園樹干與樹枝分割的精準度》&#xff0c;改進YOLO11算法后&#xff0c;進行蘋果樹的實例分割。本期文章我們將分享關于最新的YOLO12算法改進的蘋果目標檢測。 論文題目&#xff1a;Improved YOLOv12 with LLM-Gen…

設計模式 二、創建型設計模式

GoF是 “Gang of Four”&#xff08;四人幫&#xff09;的簡稱&#xff0c;它們是指4位著名的計算機科學家&#xff1a;Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides。他們合作編寫了一本非常著名的關于設計模式的書籍《Design Patterns: Elements of Reusable…

redis,tar.gz安裝后,接入systemctl報錯解決

1. WARNING Memory overcommit must be enabled! 這種報錯&#xff0c;有兩種解決方法 1.1 修改系統參數 編輯 /etc/sysctl.conf 文件&#xff0c;設置 overcommit_memory 為 1 vm.overcommit_memory 11.2 修改redis的最大使用內存 修改配置文件 redis.conf maxmemory 1g…

Python繪圖技巧,主流繪圖庫

一、主流繪圖庫概覽 1. 核心工具對比 庫名稱特點適用場景Matplotlib基礎繪圖庫&#xff0c;高度可定制科學繪圖、論文圖表Seaborn基于Matplotlib&#xff0c;統計圖表優化數據分布、關系可視化Plotly交互式可視化&#xff0c;支持網頁輸出儀表盤、動態數據展示Pandas內置簡易…

網絡安全之前端學習(HTML篇)

前言&#xff1a;網絡安全中有一個漏洞叫xss漏洞&#xff0c;就是利用網頁引發彈窗&#xff0c;這就要求我們看得懂源碼&#xff0c;所以我會持續更新前端學習&#xff0c;可以不精通&#xff0c;但是一定要會&#xff0c;主要掌握HTML&#xff0c;css&#xff0c;js這三項技術…

Qt 多線程設計:死循環與信號槽的權衡

在開發音視頻播放器時&#xff0c;多線程設計是不可避免的挑戰。音頻和視頻的解碼、播放需要高效運行&#xff0c;同時還要與主線程或其他線程同步&#xff0c;例如通過信號通知播放進度。本文基于一個實際案例&#xff0c;分析了兩種線程設計在死循環和信號槽使用中的表現&…

knowledge-微前端(多個前端應用聚合的一個應用架構體系,每個小的應用可獨立運行,獨立開發,獨立部署上線)

1.前言 微前端&#xff0c;將一個大的前端應用拆分為多個小型的&#xff0c;獨立開發的前端應用&#xff0c;每一個小型的應用都可以單獨的開發&#xff0c;部署和運行。這種結構允許不同的團隊使用不同的技術棧來開發應用的不同部分&#xff0c;提高開發的效率與靈活性。 2.實…

工廠函數詳解:概念、目的與作用

一、什么是工廠函數&#xff1f; 工廠函數&#xff08;Factory Function&#xff09;是一種設計模式&#xff0c;其核心是通過一個函數來 創建并返回對象&#xff0c;而不是直接使用 new 或構造函數實例化對象。它封裝了對象的創建過程&#xff0c;使代碼更靈活、可維護。 二、…

旋轉位置編碼(Rotary Positional Encoding, RoPE):中文公式詳解與代碼實現

旋轉位置編碼&#xff08;Rotary Positional Encoding, RoPE&#xff09;&#xff1a;中文公式詳解與代碼實現 在序列模型中&#xff0c;位置信息對于任務的理解至關重要。傳統的絕對和相對位置編碼各有優缺點&#xff0c;而RoPE作為一種創新的位置編碼方法&#xff0c;展現了…

C語言-指針變量和變量指針

指針 預備知識 內存地址 字節&#xff1a;字節是內存的容量單位&#xff0c;英文名Byte&#xff0c;1Byte8bits 地址&#xff1a;系統為了便于區分每一個字節面對它們的逐一進行編號&#xff08;編號是唯一的&#xff09;&#xff0c;稱為內存地址&#xff0c;簡稱地址。int…

unityAB包(1/2)

unityAB包學習 1.AB包的導出擴展BuildAssetBundleOptions無特殊選項壓縮相關選項 2.AB包資源管理3.Resource和AssetBundle加載方式的區別4.預設體5.Unity Asset Bundle Browser 工具5為什么要勾選拷貝到StreamingAsset里面。6.AB包的加載 1.AB包的導出 首先在Project窗口&…

算法——廣度優先搜索——跨步迷宮

原題鏈接 思路&#xff1a;找出最短路徑&#xff0c;然后判斷是否存在連續三個點是橫縱坐標相等的&#xff0c;如果有就步數減1 但是有兩個樣例過不了 錯誤原因&#xff1a;在錯誤的測試案例中&#xff0c;最短路徑可能有多條&#xff0c;而我剛好選了一條比較曲折的&#x…

某酒企數字化轉型及電商規劃項目啟動會暨培訓會v(60頁PPT)(文末有下載方式)

詳細資料請看本解讀文章的最后內容。 在當今數字化浪潮席卷之下&#xff0c;企業的發展面臨著前所未有的機遇與挑戰。對于某酒企而言&#xff0c;數字化轉型和電商規劃已成為其實現 “二次騰飛”、邁向世界級酒企的關鍵戰略舉措。本次啟動會暨培訓會&#xff0c;為該酒企的轉型…

NET6 WebApi第5講:中間件(源碼理解,俄羅斯套娃怎么來的?);Web 服務器 (Nginx / IIS / Kestrel)、WSL、SSL/TSL

一、NET6的啟動流程 區別&#xff1a; .NET6 WebApi第1講&#xff1a;VSCode開發.NET項目、區別.NET5框架【兩個框架啟動流程詳解】_vscode webapi-CSDN博客 2、WebApplicationBuilder&#xff1a;是NET6引入的一個類&#xff0c;是建造者模式的典型應用 1>建造者模式的…

vue中根據html動態渲染內容

需求&#xff1a;根據數據中的html&#xff0c;因為我是在做填空&#xff0c;所以是需要將html中的_____替換成input&#xff0c;由于具體需求我使用的是元素contenteditable代替的可編輯的input html部分 <div class"wrap"><component :is"rendered…

【AI】AI編程助手:Cursor、Codeium、GitHub Copilot、Roo Cline、Tabnine

文章目錄 一、基本特性對比二、收費標準三、私有部署能力1、Tabnine2、Roo Code 三、代碼補全與自然語言生成代碼四、安裝獨立的IDE安裝插件安裝 五、基本使用&#xff08;一&#xff09;Cursor&#xff08;二&#xff09;GitHub Copilot1、獲取代碼建議2.聊天1&#xff09;上下…

三軸云臺之角速度信號篇

三軸云臺的角速度信號主要通過其內置的傳感器&#xff08;如陀螺儀&#xff09;來感知和測量。 一、角速度信號的感知與測量 在三軸云臺中&#xff0c;陀螺儀是測量角速度的關鍵組件。它通常安裝在三個互相垂直的軸上&#xff08;通常為X、Y、Z軸&#xff09;&#xff0c;能夠…

Grid 布局實現三欄布局

使用 CSS Grid 布局實現三欄布局(左右固定 100px,中間自適應)的核心原理是通過網格模板精確控制列寬分配。以下是具體實現方法及優化技巧: 一、基礎實現 ?父容器設置 為外層容器添加 display: grid 使其成為網格容器,并通過 grid-template-columns 定義列寬 css .contain…

綠盟春招實習一面

《網安面試指南》https://mp.weixin.qq.com/s/RIVYDmxI9g_TgGrpbdDKtA?token1860256701&langzh_CN 5000篇網安資料庫https://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247486065&idx2&snb30ade8200e842743339d428f414475e&chksmc0e4732df793fa3bf39…