C/C++教程

C++中vector和map的删除方法(推荐)

本文主要是介绍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已经++了,正好满足我们的需要。

以上就是小编为大家带来的C++中vector和map的删除方法(推荐)全部内容了,希望大家多多支持找一找教程网~

这篇关于C++中vector和map的删除方法(推荐)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!