首页 >后端开发 >C++ >为什么从 `std::vector` 中删除元素时,erase-remove_if 会留下重复对?

为什么从 `std::vector` 中删除元素时,erase-remove_if 会留下重复对?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-11 20:30:03362浏览

Why does erase-remove_if leave behind duplicate pairs when removing elements from a `std::vector`?

用于删除对的 Erase-Remove_if 惯用法

当尝试使用擦除删除_if 惯用法从 std::vector 中消除对时std::pair> 出现了一个特殊的问题。尽管针对 .first 值为 4 的对进行删除,但初始实现留下了重复的对:

问题的根源在于不完整的擦除过程。 std::erase_if 仅将匹配元素移至向量末尾;它不会删除它们。要完成删除,正确的做法是使用 std::remove_if 返回的迭代器作为擦除的起点:

理解 Erase-Remove_if 机制:

  • 元素交换: std::remove_if 交换向量内的元素,将所有不匹配的元素推向开头。匹配的元素最终位于向量的后面。
  • 谓词迭代: 谓词 lambda 表达式确定要删除哪些元素。如果谓词返回 true,则相应的元素将移动到向量的末尾。
  • 迭代器检索: std::remove_if 返回一个指向与谓词匹配的第一个元素的迭代器;此迭代器标记要删除的元素的开始。
  • 向量擦除: std::vector::erase 调用范围擦除操作,从返回的迭代器开始并扩展到向量的结尾。此步骤将从向量中删除所有匹配的元素。

有关进一步的见解,请参阅关于 [擦除删除习语](https://en.wikipedia.org/) 的维基百科文章wiki/Erase-remove_idiom).

以上是为什么从 `std::vector` 中删除元素时,erase-remove_if 会留下重复对?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn