青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Mike's blog

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  0 Posts :: 23 Stories :: 83 Comments :: 0 Trackbacks

常用鏈接

留言簿(17)

我參與的團隊

搜索

  •  

最新評論

erase()函數的功能是用來刪除容器中的元素

函數原型:
iterator erase(iterator where);
iterator erase(iterator first,iterator last);
basic_string
& erase(size_type p0=0,size_type n=np);


刪除某個容器里的某個元素:c.erase(T);
看似一個簡單的動作,然而對不同類型的容器,內部卻做了截然不同的事情,后面介紹。

假設有這樣一個題目,將某個容器中所有滿足條件N == X的元素刪除,按照常規的思路應該有類似這樣的代碼:

// 假設Container和container分別表示一種容器和對應的一個對象
Container<T>::iterator it;
for (it = container.begin(); it != container.end(); ++it) {
  
if (N == X)
    container.erase(it);
}


然而這樣的代碼對于任一種容器都是錯誤的
容器按內存分配方式可以分為鏈表容器和數組容器。
所謂的鏈表容器指的是一種表現方式,包括list、slist等這樣基于節點的容器(動態分配內存塊)和set、map、multiset、multimap等關聯容器(平衡樹實現),而數組容器指的是在一塊連續的內存上保存元素的連續內存容器,比如vector、deque、string等。

OK,現在說說erase對他們的操作,鏈表容器以list為例,當執行container.erase(it)時,確實第一個滿足條件的元素刪除了,但這時it指針已經被刪除了,它也不指向任何元素了,所以也只能到此為止了,也就是說上面的代碼對于鏈表容器來說只能正確刪除第一個滿足條件的元素,針對這個問題我們首先想到的就是在刪除指針之前,給其做個備份,很好,不錯的主意,我們一般采用的方法是建立個臨時變量,這個臨時變量可以在程序循環中適當的位置使用,看下列代碼實現,是將這個臨時變量直接建立在erase實現里,這樣做更簡潔,也顯得專業些(以刪除int型鏈表中所有偶數為例,也是大家都喜歡的一個例子):

  list<int>::iterator it; 
  
for (it = lt.begin(); it != lt.end(); ) {
    
if (*it % 2 == 0)
      lt.erase(it
++);
    
else
      
++it;
  }

鏈表容器使用erase刪除節點還有一個特點,就是會將下一個元素的地址返回,所以也可以這樣實現:

  list<int>::iterator it; 
  
for (it = lt.begin(); it != lt.end(); ) {
    
if (*it % 2 == 0)
      it 
= lt.erase(it);
    
else
      
++it;
  }


當然用list容器本身提供的算法也是個不錯的主意(掛回調):

  bool evenNumber(int n)
  {
    
return (n % 2 == 0);
  }
  
  
  
  lt.remove_if(evenNumber);


數組容器以vector為例,當執行container.erase(it)時,和上面提到的一樣,第一個滿足條件的元素刪除了,但這時數組容器不允許中間有“空隙”,所以會做個大動作,就是將被刪元素后面所有的元素前移(參考STL源碼),而數組容器記錄的是下標,所以刪除元素后,當前下標定位的元素也就順理成章的變成了原有隊列中的下一個元素,同樣以刪除偶數為例,代碼如下:

  vector<int>::iterator it = v.begin();
  
for (it = v.begin(); it != v.end(); ) { 
    
if (*it % 2 == 0)
      v.erase(it);
    
else
      
++it;
  }

也可以使用reverse_iterator迭代器,并且在某些刪除操作中會有更好的效率(因為它會使上面提到的“大動作”變小一些):

  vector<int>::reverse_iterator ri = v.rbegin();
  
for ( ; ri != v.rend(); ) { 
    
if (*ri % 2 == 0
      v.erase((
++ri).base());
    
else 
      
++ri;
  }


 

posted on 2008-12-26 00:03 老狼 閱讀(2097) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美999| 欧美一进一出视频| 亚洲啪啪91| 亚洲图片欧美一区| 欧美电影在线观看| 亚洲国产欧美一区二区三区同亚洲 | 国产原创一区二区| 亚洲综合色网站| 最新国产成人在线观看| 久久综合久久88| 1024精品一区二区三区| 久久亚洲欧美| 久久精品国产精品 | 亚洲国产99| 蜜臀av性久久久久蜜臀aⅴ| 在线观看欧美一区| 欧美成人自拍视频| 欧美激情在线| 一本久久综合亚洲鲁鲁五月天| 亚洲国产精品视频| 欧美日韩高清在线一区| 中文日韩在线| 亚洲性视频h| 国产小视频国产精品| 久久免费视频在线| 久久天天躁狠狠躁夜夜爽蜜月| 影院欧美亚洲| 亚洲高清视频中文字幕| 欧美激情亚洲激情| 亚洲午夜女主播在线直播| 亚洲曰本av电影| 国产一区二区三区高清| 免费成人毛片| 欧美日韩妖精视频| 欧美一区二区三区四区夜夜大片| 欧美影院成人| 亚洲人成在线免费观看| 中文久久精品| 尤物精品在线| 亚洲每日在线| 国产综合av| 欧美激情精品久久久久久| 欧美日本在线看| 欧美在线免费播放| 久久久夜色精品亚洲| 一本到高清视频免费精品| 亚洲性感激情| 亚洲午夜在线观看| 极品av少妇一区二区| 亚洲国产人成综合网站| 国产精品青草久久久久福利99| 久久综合色婷婷| 欧美国产一区二区在线观看| 午夜在线精品偷拍| 欧美成人一二三| 久久国产一区二区| 欧美日韩一区二区三| 久久婷婷国产综合尤物精品| 欧美日韩精品高清| 欧美gay视频| 国产精品青草久久| 一区二区三区www| 1000部国产精品成人观看| 亚洲网站在线看| 亚洲国产一二三| 亚洲综合日韩在线| 一本大道久久精品懂色aⅴ| 久久久精品国产免费观看同学| 亚洲一级二级| 玖玖国产精品视频| 久久精品国产亚洲一区二区三区 | 卡通动漫国产精品| 欧美一区国产一区| 欧美另类在线播放| 欧美电影免费观看高清| 国产精品国产精品国产专区不蜜| 亚洲成色777777女色窝| 国产视频一区在线| 一区二区高清视频在线观看| 亚洲欧洲在线一区| 久久久免费精品视频| 久久经典综合| 国产精品每日更新在线播放网址| 亚洲国产激情| 亚洲欧洲精品一区二区三区| 新67194成人永久网站| 亚洲专区一区| 欧美日韩一区成人| 亚洲人成在线观看一区二区| 日韩视频―中文字幕| 欧美福利小视频| 欧美大片在线看免费观看| 一区二区三区自拍| 久久久久国产精品www| 开元免费观看欧美电视剧网站| 国产午夜精品久久久| 久久精品欧洲| 免费成人性网站| 亚洲成在人线av| 女人天堂亚洲aⅴ在线观看| 欧美大片免费久久精品三p| 亚洲片区在线| 欧美美女视频| 亚洲人成久久| 午夜精品国产精品大乳美女| 欧美性片在线观看| 亚洲一区三区在线观看| 久久国产精品亚洲77777| 国产女主播一区二区| 久久成人免费网| 久久青青草综合| 欧美激情综合网| 亚洲日本乱码在线观看| 欧美亚洲一区二区在线| 国产丝袜一区二区三区| 欧美综合国产精品久久丁香| 久久精品成人欧美大片古装| 国产亚洲电影| 亚洲成色777777女色窝| 在线视频一区观看| 国产精品久久午夜夜伦鲁鲁| 亚洲午夜激情在线| 久久亚洲影院| 亚洲精品极品| 国产精品毛片a∨一区二区三区| 亚洲一二区在线| 久久综合九色综合欧美狠狠| 亚洲精品1区2区| 欧美日韩成人在线播放| 欧美一区二区三区视频免费播放| 理论片一区二区在线| 中文久久精品| 狠狠色丁香婷婷综合久久片| 在线一区亚洲| 免费观看成人| 亚洲一区在线观看视频 | 欧美韩日视频| 亚洲视频在线观看网站| 欧美成ee人免费视频| 亚洲视频在线观看免费| 在线观看成人小视频| 欧美日韩中文精品| 狂野欧美激情性xxxx| 亚洲视频在线观看视频| 欧美国产激情| 久久久久免费视频| 亚洲视频免费在线观看| 亚洲国产mv| 国产一区二区三区在线观看精品| 欧美日韩在线亚洲一区蜜芽| 免费成人高清| 久久成人精品无人区| 亚洲一区二区三区成人在线视频精品| 免费精品视频| 久久成人18免费网站| 亚洲午夜在线观看| 亚洲激情中文1区| 在线观看欧美亚洲| 国产亚洲一二三区| 国产欧美日韩综合一区在线观看 | 午夜精品久久久久久久99水蜜桃 | 亚洲精选久久| 亚洲国产精品悠悠久久琪琪 | 久久久久久久一区| 欧美一区二区免费观在线| 一区二区国产日产| 亚洲精选国产| 日韩午夜在线播放| 亚洲国产毛片完整版| 在线成人激情黄色| 久久青草久久| 久久精品成人一区二区三区蜜臀 | 国产精品热久久久久夜色精品三区| 欧美二区在线| 欧美激情第4页| 欧美 日韩 国产一区二区在线视频| 久久久av毛片精品| 欧美影院在线| 欧美专区18| 久久久av毛片精品| 久久久久九九九九| 裸体素人女欧美日韩| 久久综合福利| 女同一区二区| 欧美日本国产视频| 欧美久久成人| 国产精品久久91| 国产精品高清在线| 国产午夜精品久久| 极品尤物久久久av免费看| 在线观看精品视频| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲国产精品成人va在线观看| 亚洲国产专区| 日韩视频―中文字幕| 亚洲女人小视频在线观看| 久久不见久久见免费视频1| 久久久精品一品道一区| 欧美肥婆在线| 亚洲精品国产精品国自产观看|