zoukankan      html  css  js  c++  java
  • C++ vector 和 map的删除

    1.连续内存序列容器(vector,string,deque)

    序列容器的erase方法返回值是指向紧接在被删除元素之后的元素的有效迭代器,可以根据这个返回值来安全删除元素。

    vector<int> c;

    for(vector<int>::iterator it = c.begin(); it != c.end();)

    { if(need_delete())   

            it = c.erase(it);  

       else   

             ++it; 

    }

     

    2.关联容器(set,multiset,map,multimap)

    关联容器的erase方法没有返回值,被删除的迭代器失效,所以删除前必须确保能得到下一个迭代器,可以用后置递增迭代器技术。

    map<int,int> m;

    for(map<int,int>::iterator it = m.begin(); it != m.end();)

    {

        if(need_delete())    

                m.erase(it++);  

        else   

                ++it;

    }

    m.erase得到it的一个副本,在erase真正开始之前it已经递增了。

    所以erase得到了当前的迭代器,在erase内部工作开始之前it已经++了,正好满足我们的需要。

  • 相关阅读:
    linux离线安装mysql
    SpringBoot配置SSL证书
    java在liunx下备份mysql数据,恢复数据
    Redis的缓存穿透,缓存击穿,缓存雪崩
    Spring缓存注解
    Advanced Algorithm Scripting
    Arguments Optional
    Everything Be True
    Binary Agents
    Steamroller
  • 原文地址:https://www.cnblogs.com/cy568searchx/p/3437120.html
Copyright © 2011-2022 走看看