namespace std {
template <class K, class H, class P, class A, class Predicate>
typename unordered_multiset<K, H, P, A>::size_type
erase_if(unordered_multiset<K, H, P, A>& c, Predicate pred);
}
概要
指定した条件に合致する要素とその分の領域を、コンテナから削除する。
効果
以下と等価:
auto original_size = c.size();
for (auto i = c.begin(), last = c.end(); i != last;) {
if (pred(*i)) {
i = c.erase(i);
} else {
++i;
}
}
return original_size - c.size();
戻り値
削除した要素数を返す。
例
#include <iostream>
#include <unordered_set>
int main()
{
std::unordered_multiset<int> us = {3, 1, 4, 1};
// コンテナusから、キー1をもつ要素をすべて削除する
std::erase_if(us, [](int x) { return x == 1; });
for (int x : us) {
std::cout << x << std::endl;
}
}
出力例
4
3
バージョン
言語
- C++20
処理系
- Clang: 8.0 ✅
- GCC: 9.1 ✅
- Visual C++: ??