【发布时间】:2019-04-22 04:53:02
【问题描述】:
我在我的代码中遇到一个常见问题,我想在它满足谓词后从反转的 std::vector 中只删除一个元素。我知道使用 range-v3 有多种方法可以做到这一点,但我想出的每种方法似乎都有些复杂。
这是目标向量 v 的示例:
std::vector v = { 1, 2, 3, 2, 4 };
结果需要是向量r:
std::vector r = { 1, 2, 3, 4 };
这将通过删除反向遍历向量 v 时找到的前 2 个(通过 lambda 谓词“is_two”)来完成。
这是在普通 C++ 原始循环中的样子:
auto is_two = [](int a) { return a == 2; };
for (int i = v.size(); --i >= 0;) {
if (is_two(v[i])) {
v.erase(v.begin() + i);
break;
}
}
这是我的坏范围-v3 版本:
namespace rs = ranges;
namespace rv = ranges::view;
namespace ra = ranges::action;
rs::for_each(v | rv::enumerate
| rv::reverse
| rv::filter([](auto i_e) { return i_e.second == 2; })
| rv::take(1),
[&](auto& i_e) { v.erase(v.begin() + i_e.first); });
理想情况下,我想知道是否有一些看起来像这样的解决方案:
ra::remove_if(v | rv::reverse, is_two);
概括地说,我想知道如何获取一个容器,通过一些 range::view 操作对其进行管道传输,然后从原始容器中删除结果范围内的元素。
【问题讨论】:
-
关键问题是如何将视图上的迭代器转换为原容器对应的迭代器。