日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

5.慎重选择删除元素的方法

發布時間:2024/4/18 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 5.慎重选择删除元素的方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

有一容器Container datas;

刪除所有值為1000的元素

對于序列容器(vector、deque、string):最好的辦法為調用慣用法erase-remove

// destData為要刪除的元素 datas.erase(std::remove(datas.begin(), datas.end(), destData), datas.end());

對于list:最好的辦法是直接調用成員函數remove()。

datas.remove(destData);

對于關聯容器(set、multiset、map、multimap):最好的辦法是調用成員函數erase()。

datas.erase(destData);

刪除滿足特定條件的所有元素,如使BadValue函數為真的元素

bool BadValue(int value);

對于序列容器:最好的辦法時使用慣用法erase-remove_if

datas.erase(std::remove_if(datas.begin(), datas.end(), BadValue), datas.end());

對于list:最好的辦法是直接調用成員函數remove_if()。

datas.remove_if(BadValue);

對于序列容器:最為麻煩,有兩種方法可供選擇。
方法1 :這種方法比較麻煩,需要先將未被移除的元素賦值到臨時容器,再使用swap交換。

... Container<int> destDatas; std::remove_copy_if(datas.begin, datas.end(), std::inserter(destDatas, destDatas.end()), BadValue); c.swap(destDatas);

方法2:直接循環處理(推薦)。

for (auto iter = datas.begin(); iter != datas.end(); ) {if (BadValue(*iter) datas.erase(iter++);?else ++iter; }

刪除滿足特定條件的所有元素(BadValue()),同時調用日志函數Log()

對于序列容器:只能通過遍歷實現。

for (auto iter = datas.begin(); iter != datas.end();) {if (BadValue(*iter)?{iter = datas.erase(iter);Log();}else ++iter; }

對于list:處理方法和序列容器一樣。

對于序列容器:依然通過遍歷,添加Log()即可。

for (auto iter = datas.begin(); iter != datas.end(); ) {if (BadValue(*iter)?{datas.erase(iter++);?}else ++iter; }

需要注意的是,通過for循環遍歷,刪除滿足條件的元素時,
序列容器更新迭代器的方法是: iter = datas.erase(iter); 因為序列容器調用erase()返回的是刪除位置后的一下位置;
關聯容器更新的方法是:datas.erase(iter++); 因為序列容器的erase()返回值為void,只能iter++的方式進行處理。
不過在C++11中,關聯容器的erase()和序列容器一樣,都返回了刪除位置后的下一位置。這樣序列容器和關聯容器的erase()就統一了。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的5.慎重选择删除元素的方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。