我经常发现自己想要根据向量的索引而不是值来过滤向量。
auto some_values = std::vector{1, 0, 4, 6, 2};
// Somewhere I figure out which items to remove.
// This may be from user interaction or something
// nothing to do with the original values:
const auto removing = std::vector<bool>{0, 0, 1, 0, 1};
Run Code Online (Sandbox Code Playgroud)
erase_if所以,我很想像这样使用:
std::erase_if(some_values, [it = removing.begin()](auto) mutable {return *it++;});
Run Code Online (Sandbox Code Playgroud)
它似乎适用于 gcc 和 clang。但是, std::erase cppref 页面上似乎没有任何关于谓词调用顺序的内容,所以我认为这是未定义的行为?
与 相同的问题std::remove_if。请注意,压缩范围不适用于大多数压缩选项,因为通常生成的范围无法调整基础数据的大小。
使用 for 循环并创建数组的副本并不是太多的样板文件,但我目前正在将过滤器应用于一些低级代码,在这些代码中我无法复制所有数据。有些数据会很大,需要在这些过滤操作期间做出响应。
最坏的情况我可以添加这样的函数来解决问题:
template <class T, auto N, class Pred>
size_t …Run Code Online (Sandbox Code Playgroud) 我有两个相等长度的整数向量.假设我要删除第一个向量中NAN的所有项.显然,我使用remove_if算法.让我们说这会删除索引1,2,5处的元素.然后我想在这些索引处从第二个向量中删除项目.
这种规范的C++最常用的方法是什么?