我是靠谱客的博主 爱笑银耳汤,最近开发中收集的这篇文章主要介绍STL中map/vector的删除元素操作,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

    在我们使用C++中的STL的时候,可以使用迭代器iterator进行遍历,但是当我们通过iterator对vector和map删除元素的时候,要格外的小心,往往操作不当,导致iterator失效,后果就是程序奔溃。

    1. 对于vector,erase会返回下一个iterator。所以一般采用的方法是:

     因为在使用erase的时候,删除元素前面的iterator有效,但是后面的iterator就不可预知了。

#include <iostream>
#include <vector>
#include <iterator>
using namespace std;
void displayAllDate(vector<int>& inputDate)
{
vector<int>::iterator itor = inputDate.begin();
cout << endl;
while (itor != inputDate.end())
{
cout << *itor << " ";
++itor;
}
}
int main()
{
vector<int> inputDate;
for (int i = 0; i < 10; i++)
{
inputDate.push_back(i);
}
vector<int>::iterator iter = inputDate.begin();
while (iter != inputDate.end())
{
if (0 == (*iter)%2)
{
iter = inputDate.erase(iter);
}
else
{
++iter;
}
}
displayAllDate(inputDate);
return 0;
}
    运行结果:

    

    2. 对于map,删除erase之后,只会影响到当前的iterator,因此我们一般推荐以下方法:

#include <iostream>
#include <map>
#include <iterator>
using namespace std;
void displayAllDate(map<int, int>& inputDate)
{
map<int, int>::iterator itor = inputDate.begin();
cout << endl;
while (itor != inputDate.end())
{
cout << itor->second << " ";
++itor;
}
}
int main()
{
map<int, int> inputDate;
for (int i = 0; i < 10; i++)
{
inputDate[i] = i + 10;
}
map<int, int>::iterator iter = inputDate.begin();
while (iter != inputDate.end())
{
if (0 == (iter->second) % 2)
{
inputDate.erase(iter++);
}
else
{
++iter;
}
}
displayAllDate(inputDate);
return 0;
}
    运行结果:

    

   但是要注意的一点,map的erase操作在window下面也可以用vector的方法实现,但是在linux下是编译不过的。所以推荐使用上面的方法。

#include <iostream>
#include <map>
#include <iterator>
using namespace std;
void displayAllDate(map<int, int>& inputDate)
{
map<int, int>::iterator itor = inputDate.begin();
cout << endl;
while (itor != inputDate.end())
{
cout << itor->second << " ";
++itor;
}
}
int main()
{
map<int, int> inputDate;
for (int i = 0; i < 10; i++)
{
inputDate[i] = i + 10;
}
map<int, int>::iterator iter = inputDate.begin();
while (iter != inputDate.end())
{
if (0 == (iter->second) % 2)
{
iter = inputDate.erase(iter);
}
else
{
++iter;
}
}
displayAllDate(inputDate);
return 0;
}
    运行结果是:

    

    参考:

    http://www.cnblogs.com/dabaopku/p/3912662.html

最后

以上就是爱笑银耳汤为你收集整理的STL中map/vector的删除元素操作的全部内容,希望文章能够帮你解决STL中map/vector的删除元素操作所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部