• <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>

            Mike's blog

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

            常用鏈接

            留言簿(17)

            我參與的團(tuán)隊

            搜索

            •  

            最新評論

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

            函數(shù)原型:
            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èi)部卻做了截然不同的事情,后面介紹。

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

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


            然而這樣的代碼對于任一種容器都是錯誤的
            容器按內(nèi)存分配方式可以分為鏈表容器和數(shù)組容器。
            所謂的鏈表容器指的是一種表現(xiàn)方式,包括list、slist等這樣基于節(jié)點(diǎn)的容器(動態(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對他們的操作,鏈表容器以list為例,當(dāng)執(zhí)行container.erase(it)時,確實(shí)第一個滿足條件的元素刪除了,但這時it指針已經(jīng)被刪除了,它也不指向任何元素了,所以也只能到此為止了,也就是說上面的代碼對于鏈表容器來說只能正確刪除第一個滿足條件的元素,針對這個問題我們首先想到的就是在刪除指針之前,給其做個備份,很好,不錯的主意,我們一般采用的方法是建立個臨時變量,這個臨時變量可以在程序循環(huán)中適當(dāng)?shù)奈恢檬褂?,看下列代碼實(shí)現(xiàn),是將這個臨時變量直接建立在erase實(shí)現(xiàn)里,這樣做更簡潔,也顯得專業(yè)些(以刪除int型鏈表中所有偶數(shù)為例,也是大家都喜歡的一個例子):

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

            鏈表容器使用erase刪除節(jié)點(diǎn)還有一個特點(diǎn),就是會將下一個元素的地址返回,所以也可以這樣實(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容器本身提供的算法也是個不錯的主意(掛回調(diào)):

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


            數(shù)組容器以vector為例,當(dāng)執(zhí)行container.erase(it)時,和上面提到的一樣,第一個滿足條件的元素刪除了,但這時數(shù)組容器不允許中間有“空隙”,所以會做個大動作,就是將被刪元素后面所有的元素前移(參考STL源碼),而數(shù)組容器記錄的是下標(biāo),所以刪除元素后,當(dāng)前下標(biāo)定位的元素也就順理成章的變成了原有隊列中的下一個元素,同樣以刪除偶數(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迭代器,并且在某些刪除操作中會有更好的效率(因?yàn)樗鼤股厦嫣岬降?#8220;大動作”變小一些):

              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 老狼 閱讀(2051) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            国产精品久久久久久久| 亚洲欧美成人久久综合中文网 | 亚洲女久久久噜噜噜熟女| 亚洲国产高清精品线久久| 91久久香蕉国产熟女线看| 亚洲国产成人精品无码久久久久久综合 | 国产一区二区久久久| 99久久精品免费看国产一区二区三区| 国内精品综合久久久40p| 久久婷婷激情综合色综合俺也去| avtt天堂网久久精品| 久久99精品久久久久久9蜜桃| 久久精品国产亚洲av麻豆蜜芽| 精品久久久久久亚洲精品| 一级做a爰片久久毛片16| 久久精品国产亚洲AV久| 国产精品美女久久久久av爽| 亚洲成色WWW久久网站| 青青青青久久精品国产h久久精品五福影院1421 | 亚洲国产高清精品线久久| 国产V综合V亚洲欧美久久| 久久99热这里只有精品国产| 久久婷婷五月综合国产尤物app| 区亚洲欧美一级久久精品亚洲精品成人网久久久久| 久久久久国产亚洲AV麻豆| 精品免费久久久久久久| 久久亚洲精品人成综合网| 欧美久久久久久精选9999| 国产精品女同久久久久电影院| 亚洲精品无码久久久久久| 青青草国产97免久久费观看| 久久综合综合久久97色| www.久久热| 午夜人妻久久久久久久久| 国产偷久久久精品专区| 99精品久久久久久久婷婷| 噜噜噜色噜噜噜久久| 欧美日韩精品久久久免费观看| 97精品伊人久久大香线蕉| 亚洲精品国精品久久99热| 国内精品久久久久久久亚洲|