欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++容器map和pair對組實例詳解

 更新時間:2024年05月15日 14:46:02   作者:Three~stone  
pair?是一種模板類,允許將兩個不同類型的值組合在一起,它由兩個數(shù)據(jù)成員first和second組成,分別用來保存這兩個值,這篇文章主要介紹了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)文章

  • C語言 sizeof 函數(shù)詳情

    C語言 sizeof 函數(shù)詳情

    這篇文章主要介紹了C語言 sizeof 函數(shù),在 C 語言中,char 字符串也是一種非常重要的數(shù)據(jù)類型,我們除了使用 sizeof 函數(shù)獲取字符串長度之外,使用 sizeof 函數(shù)同樣也可以完成字符串長度的獲取,下面文章內(nèi)容具體描述該內(nèi)容,需要的朋友可以參考以下
    2021-10-10
  • Matlab實現(xiàn)繪制高階版本韋恩圖(upset圖)

    Matlab實現(xiàn)繪制高階版本韋恩圖(upset圖)

    韋恩圖隨著階數(shù)升高會越來越復(fù)雜,當(dāng)階數(shù)達到7或者以上時幾乎沒辦法繪制,但是使用upset圖卻可以比較輕易的繪制。本文就來用Matlab實現(xiàn)繪制upset圖,需要的可以參考一下
    2023-01-01
  • C/C++?Qt?數(shù)據(jù)庫與TableView實現(xiàn)多組件聯(lián)動

    C/C++?Qt?數(shù)據(jù)庫與TableView實現(xiàn)多組件聯(lián)動

    Qt?數(shù)據(jù)庫組件與TableView組件實現(xiàn)聯(lián)動效果,本文通過案例給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-12-12
  • C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    這篇文章主要為大家詳細介紹了C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”

    C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”

    本文的主要內(nèi)容,設(shè)計一個程序,找出100-999之間的“水仙花數(shù)”,需要的朋友可以參考下
    2015-07-07
  • C/C++計算程序執(zhí)行時間的幾種方法實現(xiàn)

    C/C++計算程序執(zhí)行時間的幾種方法實現(xiàn)

    本文主要介紹了C/C++計算程序執(zhí)行時間的幾種方法實現(xiàn),包括使用clock()函數(shù)、使用庫和使用time.h頭文件中的time()函數(shù),具有一定的參考價值,感興趣的可以了解一下
    2025-02-02
  • VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn)

    VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn)

    這篇文章主要介紹了VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • C語言中循環(huán)嵌套的應(yīng)用方式

    C語言中循環(huán)嵌套的應(yīng)用方式

    這篇文章主要介紹了C語言中循環(huán)嵌套的應(yīng)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • c++11中std::move函數(shù)的使用

    c++11中std::move函數(shù)的使用

    本文主要介紹了c++11中std::move函數(shù)的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言堆與二叉樹的順序結(jié)構(gòu)與實現(xiàn)

    C語言堆與二叉樹的順序結(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

最新評論