gpt4 book ai didi

C++ reverse_iterator 备选方案

转载 作者:太空狗 更新时间:2023-10-29 21:07:53 25 4
gpt4 key购买 nike

我正在尝试编写包含一些遗留代码的二次算法。我想两次穿过一个特定的容器,一次按顺序,一次按相反的顺序。显然,我的第一个想法是使用 iteratorreverse_iterator,但奇怪的是,我正在使用的容器类的设计者认为不适合定义一个有效的 reverse_iterator 用于容器(reverse_iterators 不能像 iterators 那样取消引用)。我已经有了一个需要 reverse_iterator 的算法。

我的想法是在算法的第一部分使用第一遍迭代器,当我执行算法时 push_front 将项目放入新容器中,然后遍历新容器。这会占用内存,这在我的应用程序中并不重要,但让我想知道:在 C++ 中是否有比 reverse_iterators 更干净的替代品,或者我应该花时间只使用 forward 来修改我的算法迭代器?

最佳答案

如果您需要以相反的顺序迭代容器的元素,则不一定需要使用反向迭代器。

如果容器有双向迭代器,那么可以使用普通迭代器,使用--itend()迭代到begin() 而不是使用 ++itbegin() 迭代到 end()

由于这有点棘手,您可以使用 std::reverse_iterator 包装器将普通迭代器转换为反向迭代器(这基本上交换了 ++-- 并封装了让它工作所需的技巧)。

如果容器没有双向迭代器,那么这意味着不可能以相反的顺序迭代容器的元素,在这种情况下,您需要重写算法或使用不同的容器。

任何具有双向迭代器的容器,它应该提供反向迭代器功能;这是 STL 和 C++ 标准库“容器”概念的一部分。

关于C++ reverse_iterator 备选方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4231648/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com