c – 我可以在STL :: vector :: iterator上执行指针算术

目前我使用迭代器搜索一个向量并测试它的元素.我访问使用的元素
std::vector<int>::iterator it;
if (*it == 0);

我可以使用相同的指针算术风格逻辑来测试下一个元素(不改变我的迭代器)?

我首先需要看看它是否会将迭代器推出界限

if (it != myvec.end())

然后测试当前元素和下一个元素

if (*it == 1 && *(it + 1) == 1)

这个工作是否像我期望的那样使用指针?

解决方法

是的,std :: vector的迭代器是 random access iterators,所以你加/减积分值来获得其他有效的迭代器.

从技术上来说,它可能不是指针算术,但它们就像指针一样.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...