如何从结束到开始迭代unordered_set
How to iterate an unordered_set from the end to the begin
我想从头到尾迭代一个unordered_set:
unordered_set<Expression*> BlocExpressions;
for(auto it=BlocExpressions.end(); it != BlocExpressions.begin(); it--)
{
//do some work
}
但没有宣布operator--
。
那么,我应该编写operator--
,还是有办法做到这一点?
对于std::unordered_set
,你遍历元素的顺序并不重要。话虽如此,你可以想象顺序是随机的。无论您进行前向迭代还是向后迭代,您都不会获得特定的顺序。这就是为什么它不提供反向迭代器,也没有为普通迭代器提供--
运算符重载。向前和向后迭代在这里具有相同的语义:以随机顺序迭代。
我不明白你为什么用"结束"和"开始"这两个词来表示unordered_set unordered_set没有特定的顺序。可以使用迭代器对象循环访问所有元素。如果你需要在集合中排序,你应该使用其他容器,例如std::set
我也觉得很好奇为什么没有 rbegin() 和 rend()。我正在使用unordered_set添加随机数(无序)来表示某个路径。那就太好了。
我找到的解决方案,它可能会帮助其他人是以下解决方案。在 for 循环的第一个参数中添加递减: auto it = --BlocExpressions.end()
unordered_set<Expression*> BlocExpressions;
for(auto it = --BlocExpressions.end(); ; it--){
//do some work
// This will include the last item (which is BlocExpressions.begin())
if(it == BlocExpressions.begin()){
break;
}
}
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器