61

我想从 STL 映射中删除一个键。然而, map.erase()什么都不做。我该怎么做

4

2 回答 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 回答