C++容器map和pair對組實例詳解
pair(對組)
是一種模板類,允許將兩個不同類型的值組合在一起。它由兩個數(shù)據(jù)成員first和second組成,分別用來保存這兩個值。
頭文件
加頭文件
#include<utility>
對于 C++11 及以上標(biāo)準(zhǔn),pair 類型可以在不包含頭文件 <utility> 的情況下直接使用,因為它已經(jīng)被放入了 std 命名空間。
初始化
std::pair<int,int>f{1,2}; std::pair<int, int>ff = std::make_pair(3,4); std::pair<int, int>fff={ 1,2 };
使用
#include<iostream> int main() { std::pair<int,int>f{1,2}; std::cout << f.first << std::endl; std::cout << f.second<< std::endl; return 0; } //輸出結(jié)果是 1 2
map容器
是 C++ 標(biāo)準(zhǔn)庫中的一種關(guān)聯(lián)容器,它提供了一種鍵-值(key-value)映射的數(shù)據(jù)結(jié)構(gòu)。
在map中,每個鍵對應(yīng)一個值,鍵和值之間是一種映射關(guān)系。(就像是函數(shù)關(guān)系一樣)
特點:
動態(tài)調(diào)整大小,自動排序本質(zhì)是二叉樹結(jié)構(gòu)
map容器的使用流程
- 使用需要加入頭文件<map>
- map容器的定義及初始化
- map容器的使用
需要加入頭文件
#include<map>
map容器的定義及初始化
std::map<int, int>first { { 1,1 }, { 2,2 }}; std::map<int, int>second={ { 1,1 }, { 2,2 } }; std::map<int, int>third(second);
map容器的使用
添加元素
在map容器中每一個鍵值都是唯一的,如果插入相同的鍵那原容器的鍵所對應(yīng)的值可能會被覆蓋
使用[]添加原容器有的鍵會覆蓋容器內(nèi)的值
#include<iostream> #include<map> int main() { std::map<int, int>first { { 1,4 }, { 2,7 }}; first[1] = 33; std::cout << first[1]; return 0; } //輸出結(jié)果是 33
要向 map 容器中添加元素可以使用 insert 方法或者 emplace 方法
(使用這兩種方法不會覆蓋容器內(nèi)的值)
#include<iostream> #include<map> int main() { std::map<int, int>first { { 1,4 }, { 2,7 }}; first[1] = 33; std::cout << first[1]; return 0; } //輸出結(jié)果是 33
刪除元素
使用erase(a)刪除a元素(a為元素)
使用erase(a)刪除指定位置a的元素(a為迭代器)
使用erase(a,b)刪除指定范圍的元素(a與b為迭代器)
使用clear()刪除所有元素
訪問元素
通過訪問鍵來訪問值
有[]或者使用.at()來訪問
#include<iostream> #include<map> int main() { std::map<int, int>first { { 1,4 }, { 2,7 }}; std::cout<<first.at(2); std::cout << first[1]; return 0; } //輸出結(jié)果是 74
查找和統(tǒng)計元素
find(k);查找k是否存在,若存在,返回該鍵的元素的迭代器;若不存在,返回set.end();
count(k);統(tǒng)計k的元素個數(shù)
#include<iostream> #include<map> int main() { std::map<int, int>first { { 1,4 }, { 2,7 }}; int it = first.count(1); std::cout << it; return 0; }
注:map容器查找是找鍵值
容器操作
empty():
此函數(shù)用于判斷容器是否為空。如果容器為空,則返回true,否則返回false。
size():
此函數(shù)返回容器中實際元素的數(shù)量,也就是容器的大小
改變排序順序
使用仿函數(shù)
#include <iostream> #include <string> #include <map> // 自定義比較函數(shù)對象,按照字符串長度排序 class Compare { public: bool operator()(const std::string& str1, const std::string& str2) const { return str1.length() < str2.length(); // 按照字符串長度升序排序 } }; int main() { // 使用自定義比較函數(shù)對象來實現(xiàn)按照字符串長度排序 std::map<std::string, int, Compare> myMap = { {"one", 1}, {"three", 3}, {"two", 2} }; return 0; }
multimap容器
如果map容器有重復(fù)的值要錄入那就需要使用multimap容器,其他用法和map容器一致
到此這篇關(guān)于C++容器——map和pair對組的文章就介紹到這了,更多相關(guān)C++ map和pair對組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Matlab實現(xiàn)繪制高階版本韋恩圖(upset圖)
韋恩圖隨著階數(shù)升高會越來越復(fù)雜,當(dāng)階數(shù)達到7或者以上時幾乎沒辦法繪制,但是使用upset圖卻可以比較輕易的繪制。本文就來用Matlab實現(xiàn)繪制upset圖,需要的可以參考一下2023-01-01C/C++?Qt?數(shù)據(jù)庫與TableView實現(xiàn)多組件聯(lián)動
Qt?數(shù)據(jù)庫組件與TableView組件實現(xiàn)聯(lián)動效果,本文通過案例給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-12-12C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式
這篇文章主要為大家詳細介紹了C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”
本文的主要內(nèi)容,設(shè)計一個程序,找出100-999之間的“水仙花數(shù)”,需要的朋友可以參考下2015-07-07C/C++計算程序執(zhí)行時間的幾種方法實現(xiàn)
本文主要介紹了C/C++計算程序執(zhí)行時間的幾種方法實現(xiàn),包括使用clock()函數(shù)、使用庫和使用time.h頭文件中的time()函數(shù),具有一定的參考價值,感興趣的可以了解一下2025-02-02VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn)
這篇文章主要介紹了VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04C語言堆與二叉樹的順序結(jié)構(gòu)與實現(xiàn)
堆是計算機科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個可以被看做一棵完全二叉樹的數(shù)組對象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計的一種排序算法。本文將詳細介紹堆與二叉樹的順序結(jié)構(gòu)與實現(xiàn),需要的可以參考一下2022-05-05