STL容器之map和set

map和set

? c++98支持的是單參數的隱式類型轉換,而c++11支持多參數的隱式類型轉換;

1.map和set的使用

1.1set

? set實現key值不允許修改,是將iterator轉變成const_iterator;可以對同一個類型typedef成兩個不同的自定義標識符。即set沒有設置普通迭代器;

? set的底層是紅黑樹,使用仿函數比較大小。關聯式容器。

? set可以實現比較記錄重復次數但是需要重載仿函數,實現key_value只需要set內部實現的是一個結構體。

? count和equal_range在set容器里面一樣不大,而在multiset才有意義。

template < class T,                        // set::key_type/value_typeclass Compare = less<T>,        // set::key_compare/value_compareclass Alloc = allocator<T>      // set::allocator_type> class set;
//1.構造
empty (1)	explicit set (const key_compare& comp = key_compare(),const allocator_type& alloc = allocator_type());
range (2)	template <class InputIterator>set (InputIterator first, InputIterator last,const key_compare& comp = key_compare(),const allocator_type& alloc = allocator_type());
copy (3)	set (const set& x);
//2.迭代器
//和一起的容器一樣,迭代器底層走的是一個中序遍歷,還可以去重。
//3.insert
iterator insert (iterator position, const value_type& val);//某個迭代器位置進行插入
//4.erase
void erase (iterator position);//配合find使用,使用find找到迭代器位置。
size_type erase (const value_type& val);//根據值來進行刪除。其實就是find和erase的復用,但是會斷言。
//5.find
template <class InputIterator, class T>
InputIterator find (InputIterator first, InputIterator last, const T& val);//暴力查找會查找O(N)次
iterator find (const value_type& val) const;//因為樹的左右兩邊是平衡的,會根據大小進行比較,最多訪問高度次lg(N)次,建議優先使用它。
//6.key/value的仿函數
key_compare key_comp() const;
value_compare value_comp() const;
//7.count
size_type count (const value_type& val) const;//返回這個值出現的次數,在set中存在返回的就是1,不存在返回的就是零。
//8.找邊界
//常用在erase使用區間刪除
iterator lower_bound (const value_type& val) const;//返回的迭代器位置是大于等于這個值
iterator upper_bound (const value_type& val) const;//由于區間一般是左閉右開,所以返回的迭代器位置一般是這個值的下一位。即刪除找左閉右閉,查找找左閉右開
//9.找區間
pair<iterator,iterator> equal_range (const value_type& val) const;

1.2multiset(Multiple-key set)

? 支持鍵值冗余的multiset容器,相等的值插入在左邊和右邊都可以。

//1.count
size_type count (const value_type& val) const;//返回val的個數
//2.equal_range
pair<iterator,iterator> equal_range (const value_type& val) const;//由于set容器是一個有序的紅黑樹,所以大小相同的值的是一段連續的區間范圍,可以用pair結構來接收迭代區間的lower和upper。返回大于val數的[val+,val+)
//3.find
//相較于set的find,由于有了數據冗余,所以返回值返回的是中序遍歷的第一個val的iterator

1.3map

? 使用map來完成括號匹配問題,而且初始化用initializer_list更加方便。

? 鍵值唯一,value可重復;map內存放的是pair對象;key必須支持比較大小;如果不支持比較大小可以自己寫一個仿函數來實現,因為仿函數比較使用的就是key;

template < class Key,                                     // map::key_typeclass T,                                       // map::mapped_typeclass Compare = less<Key>,                     // map::key_compare,只有key參與比較class Alloc = allocator<pair<const Key,T> >    // map::allocator_type> class map;//相較于set多了一個模板參數,用來設置value
//1.insert
pair<iterator,bool> insert (const value_type& val);//1.value_type是一個pair<const key_type,mapped_type>,即key只讀不允許寫入,而value可讀寫;2.可以使用make_pair函數模板來實現傳入參數val或者使用隱式類型轉換;3.設置pair的原因是c++不支持返回多個參數,但是可以返回一個結構,如:解引用運算符重載返回的就是一個結構;4.key相同但是value不相同,也不會插入不會覆蓋,值比較key,不關心value;5.返回值插入成功返回true,要插入的key值存在則是false
//2.erase
void erase (iterator position);
size_type erase (const key_type& k);
//3.operator[]
mapped_type& operator[] (const key_type& k);//特點是通過key來返回value;
//對于不存在的key值會創建并用匿名對象來初始化pair,已經存在的key值會修改value值;
//底層實現就是return (*((this->insert(make_pair(k,mapped_type()))).first)).second,即使用的是insert的返回值中的迭代器位置的value。
//1.可以使用[]來實現統計出現的次數;2.可以實現插入加修改;

1.4multimap

? 支持鍵值冗余的multimap容器,value和map一樣。

? 1.相較于map沒有提供[],因為鍵值不是唯一的。

? 2.insert返回的是迭代器不是pair,因為插入一定成功;

? 3.哈希的效率可以達到O1;

1.5pair

template <class T1, class T2>
struct pair {typedef T1 first_type;typedef T2 second_type;T1 first;T2 second;pair() : first(T1()), second(T2()) {}pair(const T1& a, const T2& b) : first(a), second(b) {}
}

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

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

相關文章

Rocky 9 安裝 R-CytoTRACE

官網給出的詳細指南&#xff0c;只是可能大家打不開或者懶得去看E文。 第一步&#xff0c;下載CytoTRACE安裝包。 wget https://cytotrace.stanford.edu/CytoTRACE_0.3.3.tar.gz 第二步&#xff0c;打開R或者Rstudio-server # 安裝依賴包 if (!requireNamespace("Bioc…

在vue中$nextTick 原理及作用

在vue中$nextTick 原理及作用 Vue 的 nextTick 其本質是對 JavaScript 執行原理 EventLoop 的一種應用。 nextTick 的核心是利用了如 Promise 、MutationObserver、setImmediate、setTimeout的原生 JavaScript 方法來模擬對應的微/宏任務的實現&#xff0c;本質是為了利用 Java…

每周AI新聞(2024年第9周)微軟與Mistral AI達成合作 | 谷歌發11B基礎世界模型 | 傳蘋果放棄電動汽車制造轉向生成式AI

這里是陌小北&#xff0c;一個正在研究硅基生命的碳基生命。正在努力成為寫代碼的里面背詩最多的&#xff0c;背詩的里面最會寫段子的&#xff0c;寫段子的里面代碼寫得最好的…廚子。 每周日解讀每周AI大事件。 大廠動向 【1】微軟與Mistral AI達成合作 微軟官宣與法國生成…

視頻云平臺——搭建SRS5平臺支持GB28181視頻流的推送

&#x1f4e2;歡迎點贊 &#xff1a;&#x1f44d; 收藏 ?留言 &#x1f4dd; 如有錯誤敬請指正&#xff0c;賜人玫瑰&#xff0c;手留余香&#xff01;&#x1f4e2;本文作者&#xff1a;由webmote 原創&#x1f4e2;作者格言&#xff1a;新的征程&#xff0c;我們面對的不僅…

謹用ArrayList中的subList方法

謹用ArrayList中的subList方法 規范一&#xff1a; ArrayList 的 subList 結果不可強轉成 ArrayList&#xff0c;否則會拋出 ClassCastException 異常&#xff1a; public static void test7() {List<Integer> list new ArrayList<>();list.add(1);list.add(2);…

JavaWeb—— SpringBootWeb綜合案例(登錄功能、登錄校驗、異常處理)

案例-登錄認證 目錄 案例-登錄認證1. 登錄功能1.1 需求1.2 接口文檔1.3 思路分析1.4 功能開發1.5 測試 2. 登錄校驗2.1 問題分析2.2 會話技術2.2.1 會話技術介紹2.2.2 會話跟蹤方案2.2.2.1 方案一 - Cookie2.2.2.2 方案二 - Session2.2.2.3 方案三 - 令牌技術 2.3 JWT令牌2.3.1…

程序員眼中的“祖傳代碼”

引言 在IT界&#xff0c;特別是在Java項目中&#xff0c;“祖傳代碼”通常指的是那些經過長時間積累、由多位開發者共同維護、且蘊含深厚技術沉淀的代碼片段或模塊。這些代碼可能存在于項目的核心模塊&#xff0c;也可能是一些輔助性的工具類。它們承載著項目的歷史&#xff0…

Matlab 多項式插值(曲線擬合)

文章目錄 一、簡介二、實現代碼三、實現效果參考資料一、簡介 由于對曲線擬合有些興趣,這里就找了一些資料從最基本的方法來看一下曲線擬合的效果: 二、實現代碼 % **********

Vue.js中的路由導航守衛和其使用方法

Vue.js 中的路由導航守衛是 Vue Router 提供的一套機制&#xff0c;用于在路由切換的過程中執行自定義代碼邏輯&#xff0c;包括但不限于權限驗證、頁面滾動位置保存、加載數據等。它分為三種類型&#xff1a; 全局前置守衛 (Global beforeEach Guard) 全局前置守衛應用在整個…

python科學計算庫之Numpy庫的使用的簡單習題

Numpy庫 Numpy&#xff08;Numerical Python的縮寫&#xff09;是一個開源的Python庫&#xff0c;用于進行科學計算。它提供了一個高性能的多維數組對象&#xff08;ndarray&#xff09;及用于處理這些數組的各種工具和函數。由于其高效和靈活的數據結構以及豐富的功能&#x…

Google 地圖 API 教程--干貨(1/2)

Google Maps API 教程 在本教程中我們將學習如何使用谷歌地圖API V3創建交互式地圖。 什么是 API? API = 應用程序編程接口(Application programming interface)。 API(Application Programming Interface,應用編程接口)其實就是操作系統留給應用程序的一個調用接口,…

【d34】【Java】【力扣】27. 移除元素

題目 給你一個數組 nums 和一個值 val&#xff0c;你需要 原地 移除所有數值等于 val 的元素&#xff0c;并返回移除后數組的新長度。 不要使用額外的數組空間&#xff0c;你必須僅使用 O(1) 額外空間并 原地 修改輸入數組。 元素的順序可以改變。你不需要考慮數組中超出新長…

案例介紹:汽車售后服務網絡構建與信息抽取技術應用(開源)

一、引言 在當今競爭激烈的汽車行業中&#xff0c;售后服務的質量已成為品牌成功的關鍵因素之一。作為一位經驗豐富的項目經理&#xff0c;我曾參與構建一個全面的汽車售后服務網絡&#xff0c;旨在為客戶提供無縫的維修、保養和配件更換服務。這個項目的核心目標是通過高效的…

spring、springmvc、springboot框架的介紹

前言 我們已經學過Spring&#xff0c;SpringMVC&#xff0c;SpringBoot了&#xff0c;那這三者之間有沒有聯系或者區別呢&#xff1f; spring是一個一站式的輕量級java開發的框架&#xff0c;那我們剛開始使用spring的時候&#xff0c;是需要配置很多的配置文件以及繁瑣的過程…

狀態機實現雙擊、短按、長按等按鍵識別檢測算法

1、按鍵識別算法的作用 按鍵識別算法在不同的技術和應用背景下有不同的作用&#xff0c;但其核心目標都是準確、可靠地檢測和區分用戶通過物理或虛擬按鍵所執行的操作。按鍵識別算法在各類電子設備及系統中起到至關重要的作用&#xff0c;它確保了人機交互的有效性和準確性&…

Vue前端+快速入門【詳解】

目錄 1.Vue概述 2. 快速入門 3. Vue指令 4.表格信息案例 5. 生命周期 1.Vue概述 1.MVVM思想 原始HTMLCSSJavaScript開發存在的問題&#xff1a;操作麻煩&#xff0c;耦合性強 為了實現html標簽與數據的解耦&#xff0c;前端開發中提供了MVVM思想&#xff1a;即Model-Vi…

Mysql-主從架構篇(一主多從,半同步案例搭建)

主從架構 主從架構有什么用&#xff1f; 通過搭建MySQL主從集群&#xff0c;可以緩解MySQL的數據存儲以及訪問的壓力。 數據安全&#xff08;主備&#xff09;&#xff1a;給主服務增加一個數據備份。基于這個目的&#xff0c;可以搭建主從架構&#xff0c;或者也可以基于主…

GO語言學習筆記(與Java的比較學習)(九)

讀寫數據 讀取用戶的輸入 最簡單的辦法是使用 fmt 包提供的 Scan 和 Sscan 開頭的函數。 Scanln 掃描來自標準輸入的文本&#xff0c;將空格分隔的值依次存放到后續的參數內&#xff0c;直到碰到換行。Scanf 與其類似&#xff0c;除了 Scanf 的第一個參數用作格式字符串&…

大數據開發(Java面試真題-卷三)

大數據開發&#xff08;Java面試真題&#xff09; 1、簡要介紹以下JVM有幾種垃圾收集器&#xff1f;2、Java中Synchronized的底層原理是什么&#xff1f;3、Java String為什么是不可變的&#xff1f;為什么要設計成不可變&#xff1f;4、泛型&#xff1f;5、常用的反射方法&…

深入Java日志框架及其最佳實踐

概述 在Java應用開發中&#xff0c;日志框架是確保應用穩定性和可觀察性的關鍵組件。它幫助開發者記錄應用的行為、診斷問題&#xff0c;并監控系統的健康狀況。隨著Java生態系統的不斷發展&#xff0c;各種日志框架也應運而生&#xff0c;各有特點和優勢。本文將詳細探討幾個…