C++ 参考手册

位置:首页 > C++ 参考手册 >容器库 >std::unordered_set > std::erase_if (std::unordered_set)

定义于头文件 <unordered_set>
template< class Key, class Hash, class KeyEqual, class Alloc, class Pred >

typename std::unordered_set<Key,Hash,KeyEqual,Alloc>::size_type

    erase_if(std::unordered_set<Key,Hash,KeyEqual,Alloc>& c, Pred pred);
(C++20 起)

从容器中擦除所有满足谓词 pred 的元素。等价于

auto old_size = c.size();
for (auto i = c.begin(), last = c.end(); i != last; ) {
  if (pred(*i)) {
    i = c.erase(i);
  } else {
    ++i;
  }
}
return old_size - c.size();

参数

c - 要从中擦除的元素
pred - 若应该擦除元素则对它返回 true 的谓词

复杂度

线性。

示例

本节未完成
原因:暂无示例

参阅

移除满足特定判别标准的元素
(函数模板)