久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > map迭代器用法介紹

map迭代器用法介紹

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-20 20:09:02 1700482142

一、map迭代器使用

map是C++中常用的一個(gè)關(guān)聯(lián)數(shù)組容器,其通過key-value的形式實(shí)現(xiàn)數(shù)據(jù)存儲(chǔ)和訪問。而迭代器則是容器的重要組成部分,其可以對(duì)容器中的元素進(jìn)行訪問和操作。

在map中,迭代器通常用于遍歷map中的元素,可以先通過begin()函數(shù)獲取map的首元素,再通過對(duì)迭代器的自增操作實(shí)現(xiàn)遍歷。下面是map迭代器使用的示例代碼:

#include 
#include 

int main() {
    std::map myMap = {
        {"apple", 1},
        {"banana", 2},
        {"cherry", 3},
    };
    for (auto iterator = myMap.begin(); iterator != myMap.end(); iterator++) {
        std::cout << iterator->first << " : " << iterator->second << std::endl;
    }
    return 0;
}

上述代碼中,使用了auto關(guān)鍵字定義迭代器變量iterator,通過myMap.begin()獲取第一個(gè)元素的迭代器,通過myMap.end()獲取最后一個(gè)元素的迭代器,并使用for循環(huán)對(duì)map進(jìn)行遍歷,輸出每個(gè)元素的key和value。

二、map迭代器轉(zhuǎn)結(jié)構(gòu)體指針

有時(shí)候我們需要將map中的數(shù)據(jù)從容器的形式轉(zhuǎn)換成結(jié)構(gòu)體指針的形式,這時(shí)候我們可以利用迭代器來實(shí)現(xiàn)。下面的代碼示例將map中的數(shù)據(jù)轉(zhuǎn)換成結(jié)構(gòu)體指針:

#include 
#include 

struct Fruit {
    std::string name;
    int price;
};

int main() {
    std::map myMap = {
        {"apple", 1},
        {"banana", 2},
        {"cherry", 3},
    };
    Fruit* fruitPtr = nullptr;
    for (auto iterator = myMap.begin(); iterator != myMap.end(); iterator++) {
        Fruit fruit = {
            iterator->first,
            iterator->second
        };
        fruitPtr = &fruit;
        std::cout << fruitPtr->name << " : " << fruitPtr->price << std::endl;
    }
    return 0;
}

上述代碼中,首先定義了一個(gè)Fruit結(jié)構(gòu)體用于存放水果的名稱和價(jià)格。在for循環(huán)中,定義了一個(gè)fruit變量,并通過迭代器獲取到當(dāng)前遍歷到的元素的key和value值,賦值給fruit結(jié)構(gòu)體,再通過結(jié)構(gòu)體指針輸出對(duì)應(yīng)的數(shù)據(jù)。

三、map迭代器是什么

map迭代器其實(shí)是一種類似于指針的實(shí)體,其可以指向map容器中的某個(gè)元素。map迭代器可以實(shí)現(xiàn)對(duì)map容器中的元素進(jìn)行迭代訪問,主要用于實(shí)現(xiàn)遍歷、查找和刪除操作。

四、map迭代器類型

C++中的STL提供了多種類型的迭代器,map中使用的迭代器主要有const_iterator、iterator、reverse_iterator和const_reverse_iterator四種類型。

其中const_iterator和const_reverse_iterator類型的迭代器可以用于訪問map容器中的const數(shù)據(jù),而iterator和reverse_iterator類型的迭代器則用于訪問可修改的map容器中的元素。

五、map迭代器用法

在使用map迭代器時(shí),可以使用.begin()和.end()函數(shù)獲取map容器的第一個(gè)元素和最后一個(gè)元素的迭代器,也可以使用.find()函數(shù)根據(jù)key值來查找對(duì)應(yīng)元素的迭代器。

在遍歷map容器時(shí),可以直接使用迭代器指向元素,也可以使用->運(yùn)算符獲取當(dāng)前迭代器所指向的元素的key、value值。

六、map迭代器刪除

使用迭代器進(jìn)行map容器中元素的刪除時(shí),需注意一些問題。當(dāng)從map中刪除元素時(shí),會(huì)使得當(dāng)前迭代器失效,因?yàn)槠渲赶虻脑匾呀?jīng)被刪除,所以需要在刪除元素前先保存好下一個(gè)元素的迭代器,再進(jìn)行刪除操作。

下面的示例代碼演示了使用迭代器進(jìn)行map容器中元素的刪除:

#include 
#include 

int main() {
    std::map myMap = {
        {"apple", 1},
        {"banana", 2},
        {"cherry", 3},
    };
    auto iterator = myMap.begin();
    myMap.erase(iterator);
    iterator = myMap.begin();
    std::cout << iterator->first << " : " << iterator->second << std::endl;
    return 0;
}

上述代碼中,首先獲取了myMap中第一個(gè)元素的迭代器,然后通過myMap.erase()函數(shù)刪除該元素,之后需要重新獲取迭代器,才能訪問新的第一個(gè)元素。

七、map迭代器失效

使用map迭代器進(jìn)行操作時(shí),還需注意當(dāng)前迭代器是否會(huì)因?yàn)槟承┎僮鞫А3R姷那闆r有插入、刪除元素和改變?cè)豮ey值等,這些操作會(huì)使得迭代器失效。當(dāng)失效時(shí),會(huì)產(chǎn)生運(yùn)行時(shí)錯(cuò)誤,因此在進(jìn)行這些操作時(shí),需要注意迭代器的使用。

八、map迭代器實(shí)現(xiàn)

map迭代器的實(shí)現(xiàn)原理其實(shí)就是重載了C++中的*運(yùn)算符和->運(yùn)算符。當(dāng)使用迭代器指向map中的某一個(gè)元素時(shí),可以直接通過*iterator來獲取該元素的value值,也可以通過iterator->first和iterator->second來獲取該元素的key和value值。

九、map迭代器轉(zhuǎn)為列表

除了使用迭代器遍歷map元素外,有時(shí)我們也需要將map轉(zhuǎn)換為列表的形式,這時(shí)候可以利用迭代器和STL中的std::list容器來實(shí)現(xiàn)。下面的代碼示例展示了將map轉(zhuǎn)為列表的操作:

#include 
#include 
#include 

struct Fruit {
    std::string name;
    int price;
};

int main() {
    std::map myMap = {
        {"apple", 1},
        {"banana", 2},
        {"cherry", 3},
    };
    std::list myFruitList;
    for (auto iterator = myMap.begin(); iterator != myMap.end(); iterator++) {
        Fruit fruit = {
            iterator->first,
            iterator->second
        };
        myFruitList.push_back(fruit);
    }
    for (auto it : myFruitList) {
        std::cout << it.name << " : " << it.price << std::endl;
    }
    return 0;
}

上述代碼中,定義了一個(gè)Fruit結(jié)構(gòu)體用于存放水果的名稱和價(jià)格。在for循環(huán)中,同樣是先通過迭代器獲取到當(dāng)前遍歷到的元素的key和value值,賦值給fruit結(jié)構(gòu)體,再將fruit結(jié)構(gòu)體插入到list容器中。最后再通過for循環(huán)遍歷整個(gè)list容器,輸出每個(gè)元素的key和value。

十、map迭代器中刪除選取

map迭代器中的刪除選取操作即遍歷元素進(jìn)行判斷后進(jìn)行刪除操作,下面的代碼示例演示了如何實(shí)現(xiàn)刪除名字中有字母'a'的元素:

#include
#include

int main() {
    std::map myMap = {
        {"apple", 1},
        {"banana", 2},
        {"cherry", 3},
    };
    std::map::iterator it;
    for (it = myMap.begin(); it != myMap.end();) {
        if ((it->first).find('a') != std::string::npos) {
            myMap.erase(it++);
        } else {
            ++it;
        }
    }
    for (it = myMap.begin(); it != myMap.end(); ++it) {
        std::cout << it->first << " : " << it->second << "\n";
    }
    return 0;
}

上述代碼中,使用for循環(huán)遍歷元素,當(dāng)元素的名字中包含字母'a'時(shí),通過迭代器對(duì)其進(jìn)行刪除操作。需要注意的是,刪除元素后需要重新獲取迭代器指向下一個(gè)元素,否則會(huì)導(dǎo)致后續(xù)程序的異常。

tags: map迭代器
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
如何啟動(dòng)Kibana

一、啟動(dòng)Kibana命令啟動(dòng)Kibana最簡(jiǎn)單的方法是運(yùn)行以下命令:bin/kibana這將啟動(dòng)Kibana并將其連接到Elasticsearch實(shí)例。默認(rèn)情況下,Kibana運(yùn)行...詳情>>

2023-11-20 22:15:02
詳解atan2f函數(shù)

一、atan2返回atan2函數(shù)是C++中的數(shù)學(xué)函數(shù)之一,它的作用是計(jì)算出兩個(gè)坐標(biāo)點(diǎn)之間的夾角。在計(jì)算機(jī)圖像學(xué)領(lǐng)域中,使用atan2函數(shù)非常廣泛。在使用...詳情>>

2023-11-20 21:57:03
詳解pd.cut函數(shù)

一、pd.cut用法pd.cut()是一個(gè)用于將連續(xù)變量轉(zhuǎn)換成離散變量的函數(shù),通俗地說就是將一組數(shù)據(jù)按照一定的規(guī)則自動(dòng)分成幾段,然后用這幾段來表示原...詳情>>

2023-11-20 21:31:50
如何完全卸載wine

一、卸載wine安裝的軟件在卸載wine之前,首先需要卸載通過wine安裝的軟件,否則這些軟件可能會(huì)影響到wine的卸載過程。卸載軟件的方法與在Window...詳情>>

2023-11-20 21:24:38
Qt時(shí)間戳轉(zhuǎn)換日期格式

一、概述Qt是一個(gè)跨平臺(tái)的GUI開發(fā)框架,它提供了一套豐富的API,可以用C++進(jìn)行編程。在Qt中,時(shí)間戳是指一個(gè)整數(shù),代表從某個(gè)固定時(shí)間點(diǎn)經(jīng)過了...詳情>>

2023-11-20 20:59:26