C++中關(guān)于set刪除的一些坑

前言

公司主營(yíng)業(yè)務(wù):成都做網(wǎng)站、網(wǎng)站制作、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出桂東免費(fèi)做網(wǎng)站回饋大家。

最近工作中需要使用平衡樹(shù)維護(hù)操作。遂調(diào)用了C++標(biāo)準(zhǔn)庫(kù)里的set,在確保解題思路沒(méi)有出錯(cuò)的情況下,我發(fā)現(xiàn)自己始終有一組樣例無(wú)法通過(guò)。在檢查了很久的細(xì)節(jié)并找了標(biāo)程對(duì)跑中間過(guò)程以后,我發(fā)現(xiàn)我在使用set做刪除的時(shí)候,迭代器發(fā)生了和我預(yù)想不一樣的變化。

我在一個(gè)函數(shù)中調(diào)用了set的erase操作來(lái)刪除某個(gè)迭代器,函數(shù)的傳入?yún)?shù)為要?jiǎng)h除的迭代器,類似如下

set<int> aha;
 
void del(set<int>::iterator it)
{
 //一頓操作
 aha.erase(it);
}

然后我在main中想要?jiǎng)h除一個(gè)迭代器,并左移一位或右移一位迭代器,類似如下

int main()
{
 set<int>::iterator now;
 //一頓操作
 
 //操作1
 now=aha.find(5);
 del(now);
 now--;

 //操作2
 now=aha.find(8);
 del(now);
 now++;
}

上面是我原來(lái)的寫法,刪除這個(gè)迭代器所在的位置,然后移位。

但理想很美好,現(xiàn)實(shí)有差距。在我用標(biāo)程對(duì)拍以后,我發(fā)現(xiàn)上述操作存在很大問(wèn)題。

使用erase操作刪除一個(gè)迭代器以后,我訪問(wèn)該迭代器,他仍舊是原來(lái)的值。

但當(dāng)我想要左右移位時(shí),經(jīng)測(cè)試發(fā)現(xiàn)不管你左移還是右移,他返回的都是刪除的迭代器在原set中的前一個(gè)位置。
也即

set<int>::iterator now=aha.find(8);
del(now);
/*
現(xiàn)在--now和++now都是同一個(gè)位置
為未刪除now的set中,now的前一個(gè)位置
*/

了解這個(gè)就好辦了,我預(yù)先存下我要?jiǎng)h除的位置,然后迭代器先更新,再調(diào)用刪除即可。

這個(gè)主要還是對(duì)STL不夠熟悉造成的,為此,我后來(lái)還去翻閱了set中erase操作的函數(shù)原型及返回值。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。

分享標(biāo)題:C++中關(guān)于set刪除的一些坑
文章出自:http://www.muchs.cn/article36/ghoepg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、網(wǎng)站策劃標(biāo)簽優(yōu)化、微信公眾號(hào)營(yíng)銷型網(wǎng)站建設(shè)、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)