Home > Backend Development > C++ > How Do I Efficiently Remove Elements by Value from an STL Vector?

How Do I Efficiently Remove Elements by Value from an STL Vector?

Patricia Arquette
Release: 2024-11-22 12:44:15
Original
344 people have browsed it

How Do I Efficiently Remove Elements by Value from an STL Vector?

Erasing Elements from an STL Vector by Value

When working with STL vectors, removing an element by its value may appear to be a basic operation, yet there seems to be no straightforward method within the vector class itself.

The std::remove function provides a solution for this common task. However, it's important to note that std::remove does not directly remove elements from the container. Instead, it repositions elements that satisfy a given condition to the beginning of the container. To complete the removal process, this modified container must be passed to container_type::erase to remove the redundant elements now located at the end.

Consider the following example:

std::vector<int> vec;
// .. populate vec ..
int int_to_remove = n;
vec.erase(std::remove(vec.begin(), vec.end(), int_to_remove), vec.end());
Copy after login

In this example, std::remove repositions all elements not equal to int_to_remove to the beginning of the vector, and returns an iterator pointing to the first element after these elements. This iterator is then used as the argument to std::erase(), effectively removing the remaining elements at the end of the vector.

The above is the detailed content of How Do I Efficiently Remove Elements by Value from an STL Vector?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template