服务器之家

服务器之家 > 正文

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

时间:2021-04-24 13:46     来源/作者:jingxian

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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方法没有返回值,被删除的迭代器失效,所以删除前必须确保能得到下一个迭代器,可以用“后置递增迭代器”技术。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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的删除方法(推荐)全部内容了,希望大家多多支持服务器之家~

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
返回顶部