Movatterモバイル変換


[0]ホーム

URL:


cppreference.com
Namespaces
Variants
    Actions

      std::erase,std::erase_if(std::list)

      From cppreference.com
      <cpp‎ |container‎ |list

      [edit template]
       
       
       
      std::list
      Member functions
      Non-member functions
      erase(std::list)erase_if(std::list)
      (C++20)(C++20)
      (until C++20)(until C++20)(until C++20)(until C++20)(until C++20)
      Deduction guides(C++17)
       
      Defined in header<list>
      (1)
      template<class T,class Alloc,class U>

      typenamestd::list<T, Alloc>::size_type

          erase(std::list<T, Alloc>& c,const U& value);
      (since C++20)
      (until C++26)
      template<class T,class Alloc,class U= T>

      constexprtypenamestd::list<T, Alloc>::size_type

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

      typenamestd::list<T, Alloc>::size_type

          erase_if(std::list<T, Alloc>& c, Pred pred);
      (2)(since C++20)
      (constexpr since C++26)
      1) Erases all elements that compare equal tovalue from the containerc. Equivalent toreturn c.remove_if([&](constauto& elem)->bool{return elem== value;});.
      2) Erases all elements that satisfy the predicatepred from the containerc. Equivalent toreturn c.remove_if(pred);.

      Contents

      [edit]Parameters

      c - container from which to erase
      value - value to be removed
      pred - unary predicate which returns ​true if the element should be erased.

      The expressionpred(v) must be convertible tobool for every argumentv of type (possibly const)T, regardless ofvalue category, and must not modifyv. Thus, a parameter type ofT&is not allowed, nor isT unless forT a move is equivalent to a copy(since C++11).​

      [edit]Return value

      The number of erased elements.

      [edit]Complexity

      Linear.

      Notes

      Unlikestd::list::remove,erase accepts heterogeneous types and does not force a conversion to the container's value type before invoking the== operator.

      Feature-test macroValueStdFeature
      __cpp_lib_algorithm_default_value_type202403(C++26)List-initialization forstd::erase

      [edit]Example

      Run this code
      #include <complex>#include <iostream>#include <numeric>#include <string_view>#include <list> void println(std::string_view comment,constauto& c){std::cout<< comment<<'[';bool first{true};for(constauto& x: c)std::cout<<(first? first=false,"":", ")<< x;std::cout<<"]\n";} int main(){std::list<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::list<std::complex<double>> nums{{2,2},{4,2},{4,8},{4,2}};#ifdef __cpp_lib_algorithm_default_value_typestd::erase(nums,{4,2});#elsestd::erase(nums,std::complex<double>{4,2});#endif    println("After erase {4, 2}, nums = ", nums);}

      Output:

      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: 5After erase {4, 2}, nums = [(2,2), (4,8)]

      Defect reports

      The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

      DRApplied toBehavior as publishedCorrect behavior
      LWG 4135C++20the return type of the lambda predicate used
      was deduced from predicate arguments
      the return type is
      explicitly specified asbool

      [edit]See also

      removes elements satisfying specific criteria
      (function template)[edit]
      removes elements satisfying specific criteria
      (algorithm function object)[edit]
      removes elements satisfying specific criteria
      (public member function)[edit]
      Retrieved from "https://en.cppreference.com/mwiki/index.php?title=cpp/container/list/erase2&oldid=161908"

      [8]ページ先頭

      ©2009-2025 Movatter.jp