我想从 STL 映射中删除一个键。然而, map.erase()
什么都不做。我该怎么做
问问题
107874 次
2 回答
94
这完全取决于您如何称呼它,但听起来您可能正在使用该first,last
选项。如果你是,你需要记住它会删除从 开始的元素first
,直到但不包括 last
。如果您遵循该规则,则基于迭代器的删除应该可以正常工作,无论是作为单个元素还是一个范围。
如果你用钥匙擦除,那么它也应该可以工作,当然假设钥匙在那里。
以下示例代码显示了所有三种方法的实际作用:
#include <iostream>
#include <map>
int main (void) {
std::map<char,char> mymap;
std::map<char,char>::iterator it;
mymap['a'] = 'A'; mymap['b'] = 'B'; mymap['c'] = 'C';
mymap['d'] = 'D'; mymap['e'] = 'E'; mymap['f'] = 'F';
mymap['g'] = 'G'; mymap['h'] = 'H'; mymap['i'] = 'I';
it = mymap.find ('b'); // by iterator (b), leaves acdefghi.
mymap.erase (it);
it = mymap.find ('e'); // by range (e-i), leaves acd.
mymap.erase (it, mymap.end());
mymap.erase ('a'); // by key (a), leaves cd.
mymap.erase ('z'); // invalid key (none), leaves cd.
for (it = mymap.begin(); it != mymap.end(); it++)
std::cout << (*it).first << " => " << (*it).second << '\n';
return 0;
}
输出:
c => C
d => D
于 2012-04-06T04:08:17.383 回答
13
您必须先找到迭代器
map.erase( ITERATOR ) ;
但是,为了确保安全,您需要确保 ITERATOR 存在。标准杆示例:
#include <stdio.h>
#include <map>
using namespace std ;
int main()
{
map<int,int> m ;
m.insert( make_pair( 1,1 ) ) ;
map<int,int>::iterator iter = m.find(1) ;
if( iter != m.end() )
m.erase( iter );
else puts( "not found" ) ;
}
于 2013-12-20T19:34:45.820 回答