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

Mike's blog

  C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
  0 Posts :: 23 Stories :: 83 Comments :: 0 Trackbacks

常用鏈接

留言簿(17)

我參與的團(tuán)隊(duì)

搜索

  •  

最新評(píng)論

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

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


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

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

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


然而這樣的代碼對(duì)于任一種容器都是錯(cuò)誤的
容器按內(nèi)存分配方式可以分為鏈表容器和數(shù)組容器。
所謂的鏈表容器指的是一種表現(xiàn)方式,包括list、slist等這樣基于節(jié)點(diǎn)的容器(動(dòng)態(tài)分配內(nèi)存塊)和set、map、multiset、multimap等關(guān)聯(lián)容器(平衡樹實(shí)現(xiàn)),而數(shù)組容器指的是在一塊連續(xù)的內(nèi)存上保存元素的連續(xù)內(nèi)存容器,比如vector、deque、string等。

OK,現(xiàn)在說說erase對(duì)他們的操作,鏈表容器以list為例,當(dāng)執(zhí)行container.erase(it)時(shí),確實(shí)第一個(gè)滿足條件的元素刪除了,但這時(shí)it指針已經(jīng)被刪除了,它也不指向任何元素了,所以也只能到此為止了,也就是說上面的代碼對(duì)于鏈表容器來說只能正確刪除第一個(gè)滿足條件的元素,針對(duì)這個(gè)問題我們首先想到的就是在刪除指針之前,給其做個(gè)備份,很好,不錯(cuò)的主意,我們一般采用的方法是建立個(gè)臨時(shí)變量,這個(gè)臨時(shí)變量可以在程序循環(huán)中適當(dāng)?shù)奈恢檬褂茫聪铝写a實(shí)現(xiàn),是將這個(gè)臨時(shí)變量直接建立在erase實(shí)現(xiàn)里,這樣做更簡(jiǎn)潔,也顯得專業(yè)些(以刪除int型鏈表中所有偶數(shù)為例,也是大家都喜歡的一個(gè)例子):

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

鏈表容器使用erase刪除節(jié)點(diǎn)還有一個(gè)特點(diǎn),就是會(huì)將下一個(gè)元素的地址返回,所以也可以這樣實(shí)現(xiàn):

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


當(dāng)然用list容器本身提供的算法也是個(gè)不錯(cuò)的主意(掛回調(diào)):

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


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

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

也可以使用reverse_iterator迭代器,并且在某些刪除操作中會(huì)有更好的效率(因?yàn)樗鼤?huì)使上面提到的“大動(dòng)作”變小一些):

  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 老狼 閱讀(2083) 評(píng)論(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>
            欧美三级在线视频| 亚洲三级电影全部在线观看高清| 在线不卡视频| 国模精品娜娜一二三区| 有坂深雪在线一区| 亚洲精品网址在线观看| 一区二区三区日韩精品视频| 亚洲欧美日韩精品在线| 久久久蜜桃精品| 亚洲高清不卡在线观看| 亚洲精品一二区| 午夜精品久久久久久久99樱桃| 欧美在线一级va免费观看| 久久综合久久综合九色| 欧美日韩精品免费观看视频完整| 国产精品久久看| 在线观看欧美亚洲| 亚洲靠逼com| 欧美在线视频一区二区| 你懂的成人av| 一区二区三区.www| 久久久久国内| 欧美一区中文字幕| 欧美人与性动交cc0o| 这里是久久伊人| 亚洲一区二区三区中文字幕| 国产欧亚日韩视频| 男人的天堂亚洲在线| 欧美精品videossex性护士| 在线视频亚洲| 亚洲欧美电影院| 影音先锋欧美精品| 亚洲电影av在线| 欧美性色综合| 久久精品日韩| 免费日韩精品中文字幕视频在线| 亚洲国产天堂网精品网站| 亚洲日本在线观看| 国产精品日韩一区二区| 黄色精品一二区| 亚洲精品久久久一区二区三区| 欧美午夜电影在线| 久久久久久网| 欧美日韩成人一区| 久久av一区二区三区漫画| 久久人人爽国产| 国产精品久久久久91| 久久久久久亚洲精品杨幂换脸 | 久久综合中文字幕| 日韩亚洲成人av在线| 亚洲一区久久| 亚洲成人原创| 中文国产亚洲喷潮| 在线精品一区二区| 亚洲欧美经典视频| 国产午夜精品久久久| 免费亚洲电影在线观看| 欧美日韩国产黄| 久久激情五月婷婷| 欧美精品97| 免费亚洲一区| 国产精品高潮久久| 免费成人小视频| 久久久五月天| 欧美一区二区在线看| 欧美日韩调教| 亚洲第一精品福利| 国语自产在线不卡| 亚洲一区二区三区四区中文 | 国产亚洲精品久久久久婷婷瑜伽| 欧美成人一区二区三区在线观看| 国产精品毛片a∨一区二区三区| 亚洲国产专区校园欧美| 激情一区二区三区| 亚洲欧美怡红院| 午夜精品视频一区| 欧美日韩情趣电影| 亚洲欧洲一区二区三区在线观看| 好看的日韩视频| 午夜视频一区在线观看| 亚洲欧美中文日韩在线| 欧美日本韩国一区| 亚洲黄色尤物视频| 亚洲电影第三页| 欧美视频在线观看| 另类av一区二区| 欧美日韩一区二区三区视频| 久久精品1区| 99国产精品99久久久久久粉嫩| 国产精品尤物福利片在线观看| 亚洲最新色图| 亚洲欧美一区二区三区极速播放| 国产精品igao视频网网址不卡日韩| 亚洲精品极品| 在线午夜精品自拍| 国产精品美女久久久久久久| 亚洲一区在线观看视频| 欧美一区二区高清在线观看| 国产乱码精品一区二区三区忘忧草| 亚洲欧美国产精品va在线观看| 久久成人免费日本黄色| 亚洲国产精品悠悠久久琪琪| 亚洲国产欧美国产综合一区| 欧美成人中文| 一区二区三区鲁丝不卡| 亚洲视频一起| 国产麻豆9l精品三级站| 午夜精品久久久久久久99樱桃 | 这里只有精品电影| 国产精品久久久久久久7电影| 亚洲先锋成人| 亚洲美女少妇无套啪啪呻吟| 亚洲第一搞黄网站| 亚洲国产女人aaa毛片在线| 你懂的视频欧美| 日韩一级大片| 欧美一区二区三区精品电影| 黄页网站一区| 欧美电影在线观看| 亚洲午夜精品网| 久久青青草综合| 日韩午夜一区| 国产麻豆综合| 久久一区激情| 亚洲免费成人av| 久久久亚洲一区| 亚洲老司机av| 国产欧美综合一区二区三区| 欧美暴力喷水在线| 亚洲欧美日韩一区二区三区在线观看 | 巨乳诱惑日韩免费av| 亚洲精品影视在线观看| 国产精品久久久久久亚洲毛片| 久久精品国产第一区二区三区最新章节 | 欧美成人精品高清在线播放| 一本一道久久综合狠狠老精东影业 | 在线日本高清免费不卡| 亚洲高清123| 日韩视频在线观看| 欧美女同在线视频| 日韩视频永久免费观看| 亚洲午夜av电影| 久久久成人精品| 在线视频你懂得一区| 国产日韩专区| 欧美日韩亚洲精品内裤| 久久裸体视频| 亚洲欧美日韩精品| 欧美日韩国产三区| 亚洲女同精品视频| 久久久最新网址| 亚洲国产精品va在线看黑人| 欧美激情在线播放| 亚洲性图久久| 男人的天堂亚洲在线| 日韩午夜激情电影| 国产精品久久久一本精品| 久久国产精品久久w女人spa| 欧美成人国产| 午夜在线电影亚洲一区| 在线播放日韩专区| 欧美日韩亚洲一区二区三区在线观看| 亚洲一级黄色| 亚洲第一黄色| 欧美在线黄色| 亚洲国产欧美一区| 久久综合九色综合欧美狠狠| 欧美v日韩v国产v| 欧美激情第二页| 亚洲欧美综合网| 国产亚洲欧洲| 久久伊人免费视频| 亚洲精品一区中文| 久久精品国产成人| 日韩视频三区| 国产一区免费视频| 欧美激情中文不卡| 久久本道综合色狠狠五月| 最新成人av网站| 久久成人国产| 在线一区欧美| 在线看欧美日韩| 国产精品区一区二区三| 欧美国产日韩亚洲一区| 久久动漫亚洲| 亚洲一区二区三区高清不卡| 亚洲国产欧美在线| 久久九九热re6这里有精品| 99亚洲一区二区| 亚洲福利久久| 国产亚洲欧洲997久久综合| 欧美三区在线观看| 欧美不卡在线视频| 久久久精品tv| 欧美一区二区在线看| 宅男噜噜噜66一区二区66| 亚洲国产精品va在看黑人| 久久只精品国产| 欧美伊人久久久久久午夜久久久久| 亚洲伦理自拍|