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

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 老狼 閱讀(2107) 評論(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>
            亚洲丁香婷深爱综合| 欧美激情视频网站| 一本一本久久| 久久免费一区| 久久国产精品一区二区| 国产精品v欧美精品∨日韩| 免费亚洲一区二区| 国产小视频国产精品| 一区二区免费在线播放| 亚洲精品综合精品自拍| 美女视频黄a大片欧美| 久久久久91| 国产精品欧美经典| 一本大道久久a久久综合婷婷| 亚洲人久久久| 免费不卡在线视频| 欧美丰满少妇xxxbbb| 亚洲成人自拍视频| 久久噜噜噜精品国产亚洲综合| 久久精品视频免费播放| 国产欧美一区二区精品性色| 亚洲在线播放| 久久精品99无色码中文字幕| 国产欧美一区二区精品秋霞影院| 在线中文字幕一区| 亚洲欧美中文日韩在线| 欧美色视频日本高清在线观看| 亚洲精品影院在线观看| 99成人在线| 欧美日韩在线影院| 亚洲一二三级电影| 性色av一区二区三区| 国产精品欧美日韩久久| 亚洲综合日韩在线| 久久国产免费| 精品88久久久久88久久久| 久久精品国产77777蜜臀| 美国十次了思思久久精品导航| 一区视频在线| 蜜臀久久久99精品久久久久久 | 亚洲天堂成人在线视频| 午夜精品福利一区二区三区av| 国产精品久久看| 性久久久久久久久久久久| 久久国产欧美日韩精品| 狠狠做深爱婷婷久久综合一区| 久久女同精品一区二区| 亚洲国产高清一区| 亚洲一区免费| 国内精品一区二区| 免费一区视频| 一区二区av| 久久久精品国产99久久精品芒果| 尹人成人综合网| 欧美日韩另类综合| 性8sex亚洲区入口| 蜜桃久久av一区| 亚洲午夜羞羞片| 国产亚洲欧美一区在线观看| 毛片一区二区| 亚洲免费视频一区二区| 欧美激情精品久久久久久| 亚洲系列中文字幕| 黄色欧美日韩| 欧美午夜不卡在线观看免费| 久久精品二区三区| 亚洲久久一区| 久久久中精品2020中文| 夜夜嗨一区二区三区| 国产日韩欧美综合| 欧美三区在线视频| 久久人人爽爽爽人久久久| 中国成人在线视频| 欧美高清视频免费观看| 欧美中文字幕视频在线观看| 亚洲破处大片| 国内精品久久久| 欧美日韩在线第一页| 另类激情亚洲| 小辣椒精品导航| 制服丝袜亚洲播放| 亚洲精品一区二区在线观看| 老司机免费视频一区二区| 亚洲制服欧美中文字幕中文字幕| 亚洲国产欧美一区| 国内久久精品| 国产欧美一区二区三区在线看蜜臀 | 亚洲电影在线| 国产日韩欧美综合在线| 国产精品爱久久久久久久| 欧美成人免费小视频| 欧美在线视频不卡| 亚洲欧美一级二级三级| 亚洲调教视频在线观看| 亚洲乱码久久| 亚洲精品国产欧美| 亚洲成色777777女色窝| 欧美日韩大片| 欧美高清在线一区| 久久人体大胆视频| 久久久久免费| 久久久久一区| 老司机免费视频久久 | 亚洲视频碰碰| 99精品热视频| 9久草视频在线视频精品| 亚洲国产精品久久久久秋霞影院| 欧美成在线观看| 欧美成人福利视频| 欧美激情中文不卡| 亚洲精品韩国| 亚洲毛片一区二区| 夜久久久久久| 亚洲午夜精品视频| 亚洲自拍三区| 欧美一区二区三区视频| 欧美中文在线免费| 久久久亚洲国产天美传媒修理工| 久久综合久久综合久久综合| 久久亚洲精品网站| 欧美电影在线观看完整版| 欧美极品一区| 国产精品都在这里| 国产午夜精品美女毛片视频| 国产亚洲综合性久久久影院| 一区在线电影| 日韩网站在线观看| 午夜一区在线| 久久理论片午夜琪琪电影网| 欧美不卡视频一区发布| 亚洲国产精品久久91精品| 日韩视频亚洲视频| 午夜精品理论片| 麻豆精品网站| 欧美性开放视频| 激情久久一区| 日韩一级精品| 久久精品国产欧美激情| 欧美国产综合视频| 99成人精品| 久久久精品免费视频| 欧美日韩免费观看一区二区三区 | 亚洲高清三级视频| 一本色道久久88亚洲综合88| 欧美一区视频| 亚洲国产精品一区二区www在线| 日韩午夜高潮| 久久精品一本| 欧美视频在线看| 亚洲国产日韩欧美综合久久| 亚洲欧美日韩在线一区| 美国三级日本三级久久99| 99精品国产99久久久久久福利| 欧美在线播放| 欧美日韩亚洲综合在线| 精品动漫3d一区二区三区免费版 | 亚洲欧美日韩视频二区| 欧美大秀在线观看| 亚洲欧美大片| 欧美精品在线播放| 激情欧美一区二区| 亚洲欧美成人一区二区三区| 欧美电影免费观看大全| 亚洲欧美日韩系列| 欧美色精品在线视频| 亚洲精品少妇| 欧美77777| 性欧美暴力猛交另类hd| 欧美日韩一区国产| 亚洲欧洲精品一区二区| 久久久精品一区| 亚洲综合色丁香婷婷六月图片| 欧美电影免费观看大全| 精品999久久久| 久久精品99国产精品酒店日本| 一区二区三区欧美激情| 欧美激情亚洲另类| 亚洲国产精品悠悠久久琪琪| 久久久精品国产免大香伊| 亚洲女同精品视频| 国产精品视频精品视频| 亚洲视频在线二区| 亚洲激情视频网| 免费在线观看日韩欧美| 一区在线电影| 美国十次成人| 久久免费国产精品1| 韩国在线视频一区| 久久先锋影音av| 久久精品欧美| 精品福利免费观看| 美日韩丰满少妇在线观看| 久久精品视频一| 在线观看国产精品网站| 男人的天堂亚洲| 久久亚洲综合网| 亚洲欧洲一区二区三区久久| 欧美激情一区二区三区不卡| 欧美大片在线观看| 一本大道久久a久久精二百|