如何实现等范围"iterator"
How to implement equal range "iterator"
如何实现泛型(又名适用于多映射、排序向量…)等范围迭代器?我的意思是,它是一个迭代器,是一对迭代器(特定equal_range的开始和结束)
这样做的动机是,我有一个名为sortedword2word的多映射,我用它来检测字符串数组中的变位词。因此,我想有一种方法可以轻松地在每个相等的范围内迭代(就像LOC/可读性方式一样轻松——我知道我可以通过手动检查.end()以及next是否与current相同来轻松地完成…)
如果boost已经实现了这样的功能,那也是可以接受的。
可能是这样的:
template <typename Iter> class eqrange
{
Iter a, b, e;
void adv()
{
e = a;
while (e != b && *e == *a) { ++e; }
}
public:
eqrange(Iter x, y) : a(x), b(y) { adv(); }
Iter begin() { return a; }
Iter end() { return e; }
eqrange & operator++() { b = e; adv(); }
bool operator==(eqrange const & rhs) const
{
return a == rhs.a && b == rhs.b && e == rhs.e;
}
eqrange make_end() const
{
return eqrange(b, b);
}
};
template <typename Iter>
eqrange<Iter> er(Iter b, Iter e)
{
return eqrange<Iter>(b, e);
}
用法:
auto r = er(v.begin(), v.end()), e = r.make_end();
while (r != e)
{
for (auto x : r) { /* ... */ }
++r;
}
编写自定义迭代器可能会很痛苦(如果要严格满足ForwardIterator
概念的所有要求)。
以下内容足够吗?
template <typename Range, typename Func>
void foreach_equal_range(Range& range, Func func)
{
using std::begin;
using std::end;
foreach_equal_range(begin(range), end(range), func);
}
template <typename ForwardIt, typename Func>
void foreach_equal_range(ForwardIt begin, ForwardIt end, Func func)
{
while (begin != end)
{
auto it = std::upper_bound(begin, end, *begin);
func(begin, it);
begin = it;
}
}
我会这样做(希望我能详细理解这个问题…):
template<typename Container, typename Function>
void apply(Container& a, const Container& b, Function f)
{
auto aItr = a.begin();
auto bItr = b.begin();
for (; aItr != a.end() && bItr != b.end(); ++aItr, ++bItr)
f(*aItr, *bItr);
}
假设您可以使用C++11,但它仍然可以很容易地修改以匹配旧的C++规范。
jav
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- 尝试通过多个向量访问变量时,向量下标超出范围
- 错误:未在此范围内声明'reverse'
- 正在将指针转换为范围
- 使用std::transform将一个范围的元素添加到另一个范围中
- 在基于范围的for循环中使用结构化绑定声明
- 如何计算数据类型的范围,例如int
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 在C++中查找范围的长度
- 如何设置一个范围来提取我想要获得的信息
- 并行用于C++17中数组索引范围内的循环
- 为左值和右值的包装器实现C++范围
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 关于:C++中异常对象的范围:为什么我没有得到副本?
- 超出范围时使用对象
- 不计算一个范围内的完美数
- ";结果类型必须是可从输入范围的值类型""构造的;创建std::vector时
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 如何实现等范围"iterator"
- Iterator范围擦除元素