您的位置:

c++ Map迭代器详解

一、c++ map迭代器用法

#include <iostream>
#include <map>
using namespace std;

int main(){
    map<int, string> mymap;
    mymap.insert({1, "one"});
    mymap[2] = "two";
    mymap[3] = "three";

    for(map<int, string>::iterator it=mymap.begin(); it!=mymap.end(); it++){
        cout << it->first << ": " << it->second << endl;
    }

    return 0;
}

上述代码创建了一个整型到字符串的映射,通过insert()和[]操作符添加了三条数据。接着,使用迭代器遍历map,并输出每个元素的键和值。map的迭代器是标准库中的双向迭代器,可以用来遍历和修改map中的元素。

二、c++ map迭代器

map的迭代器是一个指向pair类型的指针,其first成员是键,second成员是值。需要注意的是,取得迭代器的方式有两种:begin()和end()函数,并不是每次迭代器的指向都是同一个地址。

for(map<int, string>::iterator it1=mymap.begin(); it1!=mymap.end(); it1++){
    for(map<int, string>::iterator it2=mymap.begin(); it2!=mymap.end(); it2++){
        if(it1->first != it2->first){
            if(it1->second == it2->second){
                cout << it1->first << " and " << it2->first << ": " << it1->second << endl;
            }
        }
    }
}

上述代码用两个迭代器遍历map中的每个元素,并找到值相同的两个元素的键值对。

三、map迭代器访问first

迭代器可以通过->运算符或者*运算符访问键和值。

for(map<int, string>::iterator it=mymap.begin(); it!=mymap.end(); it++){
    cout << it->first << ": " << it->second << endl;
}

上述代码中,迭代器it可以通过->运算符访问first成员得到键,通过->运算符访问second成员得到值。

四、迭代器遍历map集合

map的迭代器可以像普通指针一样遍历整个集合,这意味着可以从任何位置开始遍历。但是需要注意的是,最后一个元素的迭代器并不总是指向最后一个元素。

map<int, string>::iterator it=mymap.begin();
while(it!=mymap.end()){
    cout << it->first << ": " << it->second << endl;
    it++;
}

上述代码将迭代器it初始化为map的开始迭代器位置,并通过while循环遍历整个集合。每次循环都使用++运算符增加迭代器的值。

五、map迭代器遍历删除

在遍历map集合时,删除元素会导致迭代器失效,因为迭代器指向的元素被删除后,我们无法确定其余元素的位置是否发生变化。

for(map<int, string>::iterator it=mymap.begin(); it!=mymap.end(); ){
    if(it->first == 2){
        mymap.erase(it++);
    }
    else{
        it++;
    }
}

上述代码遍历整个集合,当键等于2时,删除对应的元素。需要注意的是,删除元素后需要重新调用++运算符来遍历下一个元素。

六、map获取迭代器

map的find()成员函数可以获取指向某个键所对应的迭代器。如果要查找的键不存在,函数将返回end()迭代器。

map<int, string>::iterator it=mymap.find(2);
if(it!=mymap.end()){
    cout << it->first << ": " << it->second << endl;
}

上述代码获取键为2的迭代器,并输出其对应的值,如果不存在键为2的元素,则不输出任何内容。