欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++中vector和map的刪除方法(推薦)

 更新時間:2016年12月25日 08:55:10   投稿:jingxian  
下面小編就為大家?guī)硪黄狢++中vector和map的刪除方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1.連續(xù)內(nèi)存序列容器(vector,string,deque)

序列容器的erase方法返回值是指向緊接在被刪除元素之后的元素的有效迭代器,可以根據(jù)這個返回值來安全刪除元素。

vector<int> c;

for(vector<int>::iterator it = c.begin(); it != c.end();)

{ if(need_delete())  

    it = c.erase(it); 

  else  

     ++it; 

}

2.關(guān)聯(lián)容器(set,multiset,map,multimap)

關(guān)聯(lián)容器的erase方法沒有返回值,被刪除的迭代器失效,所以刪除前必須確保能得到下一個迭代器,可以用“后置遞增迭代器”技術(shù)。

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已經(jīng)遞增了。

所以erase得到了當前的迭代器,在erase內(nèi)部工作開始之前it已經(jīng)++了,正好滿足我們的需要。

以上就是小編為大家?guī)淼腃++中vector和map的刪除方法(推薦)全部內(nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

最新評論