std::erase_if (std::unordered_map)
来自cppreference.com
<tbody>
</tbody>
| 在标头 <unordered_map> 定义
|
||
template< class Key, class T, class Hash, class KeyEqual, class Alloc, class Pred > std::unordered_map<Key, T, Hash, KeyEqual, Alloc>::size_type erase_if( std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& c, Pred pred ); |
(C++20 起) | |
从 c 中擦除所有满足谓词 pred 的元素。
等价于
auto old_size = c.size();
for (auto first = c.begin(), last = c.end(); first != last;)
{
if (pred(*first))
first = c.erase(first);
else
++first;
}
return old_size - c.size();
参数
| c | - | 要从中擦除的容器 |
| pred | - | 若应该擦除元素则对它返回 true 的谓词
|
返回值
擦除的元素数。
复杂度
线性。
示例
参阅
| 移除满足特定条件的元素 (函数模板) | |
(C++20)(C++20) |
移除满足特定条件的元素 (算法函数对象) |