【学习笔记】erase 删除顺序迭代器后迭代器失效的解决方案

目录

我们知道类似 vector 的顺序迭代器被删除后,迭代器会失效,因为顺序迭代器在内存中是连续存储的,元素删除后,后续元素会前移。

但一些场景中,我们又需要在执行删除操作,并继续遍历迭代器,那么可以通过以下的方式进行规避。

使用 erase 返回值继续迭代

erase 执行后,会返回下一个元素的新迭代器。

cpp 复制代码
std::vector<int> vec = {1, 2, 3, 4, 5};
for (auto it = vec.begin(); it != vec.end();) {
    if (*it == 2) {  // 删除元素 2
        it = vec.erase(it);  // 返回 3 所在的新迭代器
    } else {
        ++it;  // 未删除时正常递增
    }
}
// 最终结果:vec = {1, 3, 4, 5}

使用索引进行遍历

cpp 复制代码
std::vector<int> vec = {1, 2, 3, 4, 5};
for (size_t i = 0; i < vec.size();) {
    if (vec[i] == 2) {
        vec.erase(vec.begin() + i);
    } else {
        ++i;
    }
}
// 最终结果:vec = {1, 3, 4, 5}
相关推荐
晚风(●•σ )1 小时前
C++语言程序设计——06 字符串
开发语言·c++
晚云与城2 小时前
今日分享:C++ -- list 容器
开发语言·c++
兰雪簪轩2 小时前
分布式通信平台测试报告
开发语言·网络·c++·网络协议·测试报告
jingfeng5145 小时前
C++11可变参数模板、emplace系列接口、包装器
开发语言·c++
Kevinhbr6 小时前
CSP-J/S IS COMING
数据结构·c++·算法
蕓晨6 小时前
set的插入和pair的用法
c++·算法
金古圣人6 小时前
hot100 滑动窗口
数据结构·c++·算法·leetcode·哈希算法
蒹葭玉树6 小时前
【C++上岸】C++常见面试题目--算法篇(第二十期)
c++·算法·面试
高山有多高7 小时前
详解文件操作
c语言·开发语言·数据库·c++·算法
狂奔的sherry7 小时前
单例模式(巨通俗易懂)普通单例,懒汉单例的实现和区别,依赖注入......
开发语言·c++·单例模式