我有两个向量:
struct MyData{
double value;
};
std::vector<int> remove_flags = {0, 1, 0, 0, 0, 0, 1, 0};
std::vector<MyData> data = {{},{},{},{},{},{},{},{}};
该remove_flags
向量包含一个与 大小完全相同的标志数组data
,每个标志为 0 或 1,其中 1 表示应删除数据。
我想用来remove_flags
从data
原地删除元素,即执行擦除删除习语,但基于remove_flags
. 最终结果应该是data
删除了元素,并希望remove_flags
删除了相同的元素。
手动执行此操作很烦人,我想为此使用 Range-v3。我目前正在使用 C++17。
查看文档后,我认为我没有找到解决方案,我能想到的最接近的是:
auto result = ranges::views::zip(remove_flags, data) | ranges::actions::remove_if([](std::pair<const int&, const MyData&> pair){
return pair.first != 0;
});
remove_flags.erase(result.first, remove_flags.end());
data.erase(result.second, data.end());
但是操作无法对视图 zip 进行操作,因此无法编译。如果我切换ranges::actions::remove_if
到ranges::views::remove_if
返回一个奇怪的视图对象,大概是一个实际上没有std::remove
对两个向量执行等效操作的对象。
我可以使用contaner_to
,但这将涉及副本,我不想为了方便而支付那种不必要的罚款。我已经看到了我想要在 boost 中完成的事情,其中可以使用实际的 zip 对迭代器来返回两个单独的删除结果。
Range-v3 中是否可以使用这种模式?