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

C++中的vector中erase用法實(shí)例代碼

 更新時(shí)間:2022年11月24日 09:41:27   作者:信手?jǐn)佚? 
在vector數(shù)組中我們刪除數(shù)組經(jīng)常用的就是erase方法,但是earse的用法一不注意就會(huì)出錯(cuò),今天我就遇到了,所以在這里總結(jié)一下,避免大家用錯(cuò),對(duì)vector中erase用法感興趣的朋友跟隨小編一起看看吧

  在vector數(shù)組中我們刪除數(shù)組經(jīng)常用的就是erase方法,但是earse的用法一不注意就會(huì)出錯(cuò),今天我就遇到了,所以在這里總結(jié)一下,避免大家用錯(cuò)。

1、首先介紹一下erase函數(shù)的原型:

iteratorerase(iterator position);
iteratorerase(iterator first, iterator last);

我們可以看到erase函數(shù)有兩種函數(shù)原型,一種是給定要?jiǎng)h除的位置,另一種是給定刪除的區(qū)域。

2、接下來給出一種常見的錯(cuò)誤

for(auto iter=vec.begin();iter!=vec.end(); iter++)
{
      if(*iter == 3)
            veci.erase(iter);
}

  這里面隱藏著一個(gè)很嚴(yán)重的錯(cuò)誤:當(dāng)veci.erase(iter)之后,iter就變成了一個(gè)野指針,對(duì)一個(gè)野指針進(jìn)行 iter++ 是肯定會(huì)出錯(cuò)的。
  我們通過查閱文檔可以看到erase函數(shù)的返回值是這么介紹的:一個(gè)迭代器,指定在任何刪除的元素之后剩余的第一個(gè)元素,如果不存在這樣的元素,則指定指向向量結(jié)尾的指針

將代碼改成這樣就可以了:

for(auto iter=vec.begin();iter!=vec.end(); iter++)
{
      if(*iter == 3)
            iter = veci.erase(iter);
}

  但是這種代碼也是存在缺陷的,首先是我們無法連續(xù)刪除數(shù)字3,其次是迭代器在指向vec.end()的時(shí)候,還會(huì)進(jìn)行一次++,這就發(fā)生了數(shù)組越界,所以我們一概這樣修改:

for(auto iter=vec.begin();iter!=vec.end(); )
{
     if( *iter == 3)
          iter = veci.erase(iter);//當(dāng)刪除時(shí)erase函數(shù)自動(dòng)指向下一個(gè)位置,就不需要進(jìn)行++
      else
            iter ++ ;    //當(dāng)沒有進(jìn)行刪除的時(shí)候,迭代器++
}

另一種解決無法刪除連續(xù)的數(shù)字的方法

我們先介紹一下remove函數(shù):
remove是個(gè)stl的通用算法std::remove(first,last,val)移除[first, last)范圍內(nèi)等于val的元素在vector里面用就類似于 iter=std::remove(vec.begin(), vec.end(), val)但這個(gè)函數(shù)只是把val移到vec的末尾,并不真正刪除,真正刪除還是要調(diào)用一次erase函數(shù)

veci.erase(remove(vec.begin(),vec.end(),3),vec.end());

3、刪除重復(fù)元素,并且順序不發(fā)生變化

  如果不要求順序的話,我們可以直接調(diào)用unique函數(shù)進(jìn)行操作,這里介紹一下unique函數(shù):從頭到尾,判斷當(dāng)前元素是否等于上一個(gè)元素,將不重復(fù)的元素移到前面來(賦值操作),而不是將重復(fù)的元素移動(dòng)到后面去。
函數(shù)的參數(shù)是:
first:去重的起點(diǎn)的迭代器位置。
last:去重的終點(diǎn)的迭代器位置,不包括
pred:自定義判斷重復(fù)方式。
返回值:去重以后vector中沒有重復(fù)元素的下一個(gè)位置的迭代器。

vec.erase(unique(vec.begin(),vec.end()),vec.end())  //將重復(fù)的區(qū)域刪除

但是如果要求數(shù)字順序不能發(fā)生變化呢?

這里有兩種做法:
第一種:我們直接對(duì)vector數(shù)組本身進(jìn)行操作
這里我們介紹一下find()函數(shù):函數(shù)有3個(gè)參數(shù),前兩個(gè)規(guī)定了找的區(qū)域,第三個(gè)是要找的數(shù)字。如果找到,返回其迭代器,找不到返回-1

void fun(vector<int>& vec)
{
   for(auto iter=vec.begin(); iter!=vec.end();)
   {
      auto iter1=find(vec.begin(),iter,*iter);
      if(iter!=iter1)  //判斷是否重復(fù),如果兩者相等說明沒有重復(fù)
      {
         iter = vec.erase(iter);
      }
      else
         iter++;
   }
}

第二種:創(chuàng)建一個(gè)vector來存放沒有重復(fù)的元素

vector<int> fun(vector<int>& vec)
{
   vector<int> temp;
   for(auto iter=vec.begin(); iter!=vec.end(); iter++;)
   {
      auto iter1=find(vec.begin(),iter,*iter);
      if(iter==iter1) 
      {
         temp.push_back(*iter);
      }        
   }
}

總結(jié):

  erase()函數(shù)的用法: erase()函數(shù)用于在順序型容器中刪除容器的一個(gè)元素,有兩種函數(shù)原型,c.erase (p ),c.erase(b,e);第一個(gè)刪除迭代器p所指向的元素,第二個(gè)刪除迭代器b,e所標(biāo)記的范圍內(nèi)的元素,c為容器對(duì)象,返回值都是一個(gè)迭代器,該迭代器指向被刪除元素后面的元素(這個(gè)是重點(diǎn))

到此這篇關(guān)于C++中的vector中erase用法代碼的文章就介紹到這了,更多相關(guān)vector中erase用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言深入講解宏的定義與使用方法

    C語言深入講解宏的定義與使用方法

    在 C 語言中,可以采用命令 #define 來定義宏。該命令允許把一個(gè)名稱指定成任何所需的文本,例如一個(gè)常量值或者一條語句。在定義了宏之后,無論宏名稱出現(xiàn)在源代碼的何處,預(yù)處理器都會(huì)把它用定義時(shí)指定的文本替換掉
    2022-04-04
  • 基于C++17實(shí)現(xiàn)的手寫線程池

    基于C++17實(shí)現(xiàn)的手寫線程池

    本文主要介紹了基于C++17實(shí)現(xiàn)的手寫線程池,自己實(shí)現(xiàn)了Any類,Semaphore類以及Result類的開發(fā),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • C語言求冪計(jì)算的高效解法

    C語言求冪計(jì)算的高效解法

    這篇文章主要介紹了C語言求冪計(jì)算的高效解法,分別演示了求冪運(yùn)算與整數(shù)次方的解法,具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-09-09
  • C++實(shí)現(xiàn)字符格式相互轉(zhuǎn)換的示例代碼

    C++實(shí)現(xiàn)字符格式相互轉(zhuǎn)換的示例代碼

    這篇文章主要為大家詳細(xì)介紹了C++中實(shí)現(xiàn)字符格式相互轉(zhuǎn)換的方法,主要有UTF8與string互轉(zhuǎn)、wstring與string互轉(zhuǎn),感興趣的小伙伴可以了解一下
    2022-11-11
  • c++核心編程之函數(shù)的重載

    c++核心編程之函數(shù)的重載

    這篇文章主要介紹了c++核心編程之函數(shù)的重載,函數(shù)可以重復(fù)使用,提高了復(fù)用性,但前提是必須在一個(gè)作用域并且函數(shù)名稱相同,下面附代碼詳細(xì)介紹,需要的小伙伴可以參考一下
    2022-03-03
  • C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static

    C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static

    這篇文章主要介紹了C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static,文基于C++圍繞主題展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-05-05
  • VC創(chuàng)建進(jìn)程CreateProcess的方法

    VC創(chuàng)建進(jìn)程CreateProcess的方法

    這篇文章主要介紹了VC創(chuàng)建進(jìn)程CreateProcess的方法,涉及VC操作進(jìn)程的基本技巧,需要的朋友可以參考下
    2015-05-05
  • Qt QChart 創(chuàng)建圖表的實(shí)現(xiàn)方法

    Qt QChart 創(chuàng)建圖表的實(shí)現(xiàn)方法

    這篇文章主要介紹了Qt QChart 創(chuàng)建圖表的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C++實(shí)現(xiàn)班級(jí)成績管理系統(tǒng)

    C++實(shí)現(xiàn)班級(jí)成績管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)班級(jí)成績管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++有符號(hào)和無符號(hào)之間的轉(zhuǎn)換問題

    C++有符號(hào)和無符號(hào)之間的轉(zhuǎn)換問題

    在開發(fā)中經(jīng)常會(huì)遇到有符號(hào)和無符號(hào)之間的轉(zhuǎn)換問題,如果不清楚問題根源,很難解決bug,今天小編通過本文給大家分享c++有符號(hào)無符號(hào)轉(zhuǎn)換問題,需要的朋友參考下
    2021-07-07

最新評(píng)論