《探索C++ set與multiset容器:深入有序唯一性集合的實現與應用》

前引:在STL的關聯式容器中,set以其嚴格的元素唯一性自動排序特性成為處理有序數據的核心工具。其底層基于紅黑樹(Red-Black Tree)實現,保證了O(log n)的查找、插入與刪除復雜度!本文將從底層原理切入,結合關鍵操作源碼剖析,探討set在去重排序、高效檢索等場景的工程實踐。通過對比unordered_set與自定義排序規則,揭示其在內存效率與訪問性能的平衡藝術?!

目錄

【一】set 與 multiset 的介紹

【二】特點詳解

(1)自動排序

(2)唯一元素

(3)高效操作

(4)不支持隨機訪問

(5)迭代器支持

【三】接口學習

(1)構造

(2)插入

(3)迭代器訪問

(4)范圍for訪問

(5)find 搜索+erase 刪除

(6)find 搜索 與 count搜索

(7)lower 與 upper

(8)元素個數

(9)equal_range


【一】set 與 multiset 的介紹

完整解釋:

在C++標準模板庫(STL)中,set是一種關聯容器,用于存儲唯一元素(本身是 key),并自動按升序排序。它基于紅黑樹(一種自平衡二叉搜索樹)實現,提供了高效的查找、插入和刪除操作。set常用于需要快速訪問和唯一性保證的場景,如去重、排序或作為字典鍵

set 通俗理解:

基于紅黑樹實現的一種容器,具有自動排序(升序)+不重復的特點

?multiset 通俗理解:

基于紅黑樹實現的一種容器,具有自動排序(升序)特點,但?multiset?的節點允許鍵值重復

【二】特點詳解

(1)自動排序

自動排序簡而言之就是當你存入數據到 set 容器時,它會自動把它插入到合適的位置,從而實現自動排序,感覺就像《搜索二叉樹+中序遍歷》例如:

插入(1,、9、7、6),set 容器里面存儲(1、6、7、9)

(2)唯一元素

唯一性體現在數據的獨一無二,例如:

插入(1、2、3、3、3、7、7、6),set 容器里面存儲(1、2、3、6、7)

(3)高效操作

查找 ?插入 ?刪除:我們可以根據《搜索二叉樹》理解,每次折半,那么時間復雜度可以保證在O(logn),這些高效性源于紅黑樹的平衡特性!

(4)不支持隨機訪問

它的結構不是像數組那樣的下標訪問,元素的位置由樹結構決定

(5)迭代器支持

支持正向和反向兩種迭代器(下文有例舉!)

【三】接口學習

(1)構造

set 比較常使用的是默認構造:set + 數據類型 + 變量

set<int> V;
(2)插入
V.insert(9);
(3)迭代器訪問
set<int>::iterator it = V.begin();
while (it != V.end())
{cout << *it << " ";it++;
}

(4)范圍for訪問
for (auto e : V)
{cout << e << " ";
}

(5)find 搜索+erase 刪除

第一種查找:庫里面通用的查找函數,屬于暴力查找,時間復雜度為 O(N)

第二種查找:set 容器里面的,根據 set 的結構查找,時間復雜度為 O(logn)

//搜索+刪除auto st = find(V.begin(), V.end(), 5);    //第一種
auto st = V.find(8);                      //第二種
if (st != V.end())
{V.erase(10);
}

(6)find 搜索 與 count搜索

find:如果找到指定元素了,會返回它的位置,否則返回end

count:如果找到指定元素返回1,否則返回0

(7)lower 與 upper

lower_bound:返回范圍內?>= 指定元素的位置,否則返回end

例如:(1,2,3,4,6,7,8)查找4,返回4的位置;查找5,返回6的位置

upper_bound:返回范圍內 >?指定元素的位置,否則返回end

例如:(1,2,3,4,6,7,8)查找4,返回6的位置

(8)元素個數
V.size();

(9)equal_range

返回值:

該函數返回一個?pair

其成員?pair::first?是范圍的下限(與?lower_bound?相同)>=

pair::second?是上限(與?upper_bound?相同)>

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

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

相關文章

各測試平臺功能對比分析(ITP,Postman,Apifox,MeterSphere)

對比ITP與Postman,Apifox,MeterSphere 功能特性ITPPostmanApifoxMeterSphere接口測試? 可視化接口調試&#xff0c;支持多種請求方式? 支持? 支持? 支持場景測試? 多接口串聯測試&#xff0c;支持前后置腳本? Collections功能? 支持? 支持定時任務? 基于Celery的定時…

開源日志log4cplus—如何將 string類型轉為tstring類型,又如何將char*類型轉換為tstring類型?

文章目錄&#x1f527; 一、理解 log4cplus::tstring 的本質?? 二、std::string 轉 tstring 的三種方法? 1. 使用內置宏 LOG4CPLUS_STRING_TO_TSTRING&#xff08;推薦&#xff09;? 2. 手動條件編譯轉換&#xff08;精細控制&#xff09;? 3. 多字節模式下的直接賦值??…

深度學習之CNN網絡簡介

CNN網絡簡單介紹 1.概述 卷積神經網絡&#xff08;Convolutional Neural Network&#xff0c;CNN&#xff09;是一種專門用于處理具有網格狀結構數據的深度學習模型。 ? CNN網絡主要有三部分構成&#xff1a;卷積層、池化層和全連接層構成&#xff0c;其中卷積層負責提取圖像中…

【微實驗】基頻提取的MATLAB實現(優化版)

前情提要&#xff1a; 【超詳細】科普&#xff1a;別再只會用自相關&#xff01;YIN 和 PYIN 如何破解音頻隱藏密碼&#xff1f;-CSDN博客 【微實驗】媽媽我的MATLAB會識別聲音的基頻了&#xff01;-CSDN博客 今天用MATLAB把算法封裝成函數&#xff0c;然后調用對比結果。 …

開發 npm 包【詳細教程】(含發布 npm 包,版本號升級,修改包后重新發布等)

1. 給 npm 包取個【唯一】的名字&#xff01; npm 包命名規范 只能包含小寫字母&#xff08;a-z&#xff09;、數字&#xff08;0-9&#xff09;、連字符&#xff08;-&#xff09; 和 下劃線&#xff08;_&#xff09;&#xff0c;不能包含空格、大寫字母、標點符號&#xff…

Secure 第三天作業

實驗需求&#xff1a;1.參考以上拓撲所示&#xff0c;完成以下需求&#xff1a;1&#xff09; 配置各設備 IP 地址2&#xff09; 配置 ZBFW&#xff0c;Inside-1 和 nside-2 屬于內部 Zone&#xff0c;Outside-1 屬于外部 Zonezone security insidezone security outsidezone-p…

Linux應用層-5.計算機網絡(菜鳥學習筆記)

計算機網絡的核心是連接與通信&#xff0c;從底層的物理信號到上層的應用服務&#xff0c;各層協議協同工作---------------------------------------------------------------------------------------一.計算機網絡分類&#xff08;按范圍&#xff09;1?個人區域網&#xff…

[論文閱讀] 人工智能 + 軟件工程 | 大型語言模型對決傳統方法:多語言漏洞修復能力大比拼

大型語言模型對決傳統方法&#xff1a;多語言漏洞修復能力大比拼 論文閱讀&#xff1a;On the Evaluation of Large Language Models in Multilingual Vulnerability RepairarXiv:2508.03470 On the Evaluation of Large Language Models in Multilingual Vulnerability Repair…

計算機網絡2-3:傳輸方式

目錄 串行傳輸和并行傳輸 同步傳輸和異步傳輸 單工、半雙工以及全雙工通信 總結 串行傳輸和并行傳輸 并行傳輸的優點是速度為串行傳輸的n倍&#xff0c;但也存在一個嚴重的缺點即成本高 同步傳輸和異步傳輸 單工、半雙工以及全雙工通信 總結

文檔生成PPT軟件哪個好?深度測評8款word轉ppt生成工具

在日常辦公與教學場景中&#xff0c;如何高效地將Word文檔內容轉化為專業PPT&#xff0c;一直是職場人士、教育工作者及內容創作者的共同痛點。隨著AI技術的普及&#xff0c;一鍵式轉換工具應運而生&#xff0c;它們不僅能精準識別Word中的標題與段落結構&#xff0c;還能自動套…

Azimutt:一款免費開源的多功能數據庫工具

Azimutt 是一款支持數據庫設計、表結構探索與分析、數據查詢以及數據庫文檔生成功能的全棧工具。 Azimutt 是一個免費開源的項目&#xff0c;源代碼托管在 GitHub&#xff1a; https://github.com/azimuttapp/azimutt 功能特性 多數據庫支持&#xff1a;包括主流數據庫 MySQ…

智算賦能:移動云助力“世界一流數據強港”建設之路

2024年5月&#xff0c;某創新產業園區智算中心正式揭牌成立。臺下響起的掌聲不僅是對一個項目的祝賀&#xff0c;更是客戶對未來的期許—— 推動產業結構優化升級&#xff0c;領跑數字經濟轉型發展。5家500強企業、8家上市企業、17家獨角獸企業……該創新產業園區在成為“世界一…

達夢自定義存儲過程實現獲取表完整的ddl語句

--導出表的ddl CREATE OR REPLACE PROCEDURE show_create_table( db IN varchar(255), tb IN varchar(255)) ASsql1 text;ret text : ;cmt text :;sql2 text :; BEGINFOR WSX IN (select TABLEDEF(db,tb) as ddl from dual) LOOPret: ret||WSX.DDL;END LOOP;ret : ret||chr(10…

【ARM】keil提示UVISION: Error: Encountered an improper argument

1、 文檔目標 解決MDK退出debug模式后&#xff0c;提示UVISION: Error: Encountered an improper argument。 2、 問題場景 在退出Debug模式的時候&#xff0c;彈出提示窗口&#xff0c;提示&#xff1a;UVISION: Error: Encountered an improper argument。&#xff08;如圖…

【2025最新版】PDF24 Creator,PDF編輯,合并分割,格式轉換全能工具箱,本地離線版本,完全免費!

軟件介紹&#xff08;文末獲取&#xff09;這款軟件于1999年開發&#xff0c;至今已經有26年了&#xff0c;這26年里它都完全免費&#xff01;簡潔的操作界面&#xff0c;讓用戶輕松上手&#xff0c;高效完成 PDF 文件的處理&#xff0c;方便又實用。這次給大家帶來的是一個本地…

如何使用VLLM進行openai/gpt-oss系列推理與支持工具調用

OpenAI時隔6年再次推出開源模型gpt-oss系列&#xff0c;本次gpt-oss系列包含兩個模型gpt-oss-120b與gpt-oss-20b。由于模型原生支持一種新的量化技術MXFP4&#xff0c;所以模型的部署所需的顯存也顯著的降低。openai/gpt-oss-20b 只需要大概16GB的顯存openai/gpt-oss-120b 需要…

SVN 查看歷史信息

SVN 查看歷史信息 引言 Subversion&#xff08;簡稱SVN&#xff09;是一個開源的版本控制系統&#xff0c;廣泛應用于軟件開發中。查看SVN的歷史信息對于了解代碼變更、追蹤問題來源以及理解項目發展歷程具有重要意義。本文將詳細介紹如何在SVN中查看歷史信息。 SVN歷史信息概述…

vue+flask山西非遺文化遺產圖譜可視化系統

文章結尾部分有CSDN官方提供的學長 聯系方式名片 文章結尾部分有CSDN官方提供的學長 聯系方式名片 關注B站&#xff0c;有好處&#xff01;編號&#xff1a;F068 項目介紹&#xff1a; 本系統主要實現了以下功能&#xff1a; 非遺項目知識圖譜可視化 非遺項目可視化關鍵詞分析 …

Jetson NX Python環境搭建:使用APT輕松安裝NumPy, scikit-learn, OpenCV

引言 在NVIDIA Jetson NX等ARM架構的嵌入式AI板子上搭建Python開發環境&#xff0c;特別是安裝像NumPy、OpenCV這樣包含C/C底層代碼的科學計算庫時&#xff0c;經常會遇到編譯失敗、耗時過長或依賴沖突等問題。這些問題尤其在通過pip從源代碼編譯安裝時更為突出&#xff0c;例如…

Spring Boot項目中線程池的全面教程

一、線程池基礎概念與重要性1.1 為什么需要線程池在Spring Boot應用中&#xff0c;線程池是一種至關重要的并發編程工具&#xff0c;它通過??復用線程資源??顯著提升系統性能。主要優勢包括&#xff1a;??減少開銷??&#xff1a;避免頻繁創建和銷毀線程帶來的性能損耗?…