Namespaces
Variants

std:: erase, std:: erase_if (std::vector)

From cppreference.net

헤더 파일에 정의됨 <vector>
(1)
template < class T, class Alloc, class U >

constexpr typename std:: vector < T, Alloc > :: size_type

erase ( std:: vector < T, Alloc > & c, const U & value ) ;
(C++20부터)
(C++26까지)
template < class T, class Alloc, class U = T >

constexpr typename std:: vector < T, Alloc > :: size_type

erase ( std:: vector < T, Alloc > & c, const U & value ) ;
(C++26부터)
template < class T, class Alloc, class Pred >

constexpr typename std:: vector < T, Alloc > :: size_type

erase_if ( std:: vector < T, Alloc > & c, Pred pred ) ;
(2) (C++20부터)
1) 컨테이너 c 에서 value 와 비교하여 동일한 모든 요소를 삭제합니다. 다음 코드와 동일합니다: auto it = std :: remove ( c. begin ( ) , c. end ( ) , value ) ;
auto r = c. end ( ) - it ;
c. erase ( it, c. end ( ) ) ;
return r ;
.
2) 컨테이너 c 에서 predicate pred 를 만족하는 모든 요소를 삭제합니다. auto it = std:: remove_if ( c. begin ( ) , c. end ( ) , pred ) ;
auto r = c. end ( ) - it ;
c. erase ( it, c. end ( ) ) ;
return r ;
와 동일합니다.

목차

매개변수

c - 요소를 삭제할 컨테이너
value - 제거할 값
pred - 요소가 삭제되어야 할 경우 ​ true 를 반환하는 단항 predicate.

표현식 pred ( v ) v 값 카테고리 와 무관하게 (const 가능성 있는) T 타입의 모든 인수 v 에 대해 bool 로 변환 가능해야 하며, v 를 수정해서는 안 됩니다. 따라서 T & 매개변수 타입은 허용되지 않으며 , T 에 대해 이동이 복사와 동등하지 않는 한 T 타입도 허용되지 않습니다 (C++11부터) . ​

반환값

삭제된 요소의 수.

복잡도

선형.

참고 사항

기능 테스트 매크로 표준 기능
__cpp_lib_algorithm_default_value_type 202403 (C++26) 목록 초기화 for std::erase

예제

#include <complex>
#include <iostream>
#include <numeric>
#include <string_view>
#include <vector>
void println(std::string_view comment, const auto& c)
{
    std::cout << comment << '[';
    bool first{true};
    for (const auto& x : c)
        std::cout << (first ? first = false, "" : ", ") << x;
    std::cout << "]\n";
}
int main()
{
    std::vector<char> cnt(10);
    std::iota(cnt.begin(), cnt.end(), '0');
    println("Initially, cnt = ", cnt);
    std::erase(cnt, '3');
    println("After erase '3', cnt = ", cnt);
    auto erased = std::erase_if(cnt, [](char x) { return (x - '0') % 2 == 0; });
    println("After erase all even numbers, cnt = ", cnt);
    std::cout << "Erased even numbers: " << erased << '\n';
    std::vector<std::complex<double>> nums{{2, 2}, {4, 2}, {4, 8}, {4, 2}};
    #ifdef __cpp_lib_algorithm_default_value_type
        std::erase(nums, {4, 2});
    #else
        std::erase(nums, std::complex<double>{4, 2});
    #endif
    println("After erase {4, 2}, nums = ", nums);
}

출력:

Initially, cnt = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
After erase '3', cnt = [0, 1, 2, 4, 5, 6, 7, 8, 9]
After erase all even numbers, cnt = [1, 5, 7, 9]
Erased even numbers: 5
After erase {4, 2}, nums = [(2,2), (4,8)]

참고 항목

특정 조건을 만족하는 요소들을 제거함
(함수 템플릿)
특정 조건을 만족하는 요소들을 제거함
(알고리즘 함수 객체)