博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
array学习之迭代器begin, end, cbegin, cend, rbegin, rend, rcbegin, rcend
阅读量:2193 次
发布时间:2019-05-02

本文共 1763 字,大约阅读时间需要 5 分钟。

array提供的迭代器有以下几种访问方式

begin, cbegin返回指向超始的迭代器

end,cend返回指向末尾的迭代器

rbegin,crbegin返回指向超始的逆向迭代器

rend,crend返回指向末尾的逆向迭代器

代码示例如下:

#include 
#include
#include
using namespace std;void GetIterator(){ array
nArray = {12, 23, 53, 67, 98}; for(auto &c: nArray) { cout << c << "\t"; } cout << endl; array
::iterator begin = nArray.begin();//可用auto cout << "begin === " << *begin << endl;//第一个元素 array
::const_iterator cbegin = nArray.cbegin();//可用auto cout << "cbegin == " << *cbegin << endl;//第一个元素 array
::iterator end = nArray.end() - 1;//可用auto cout << "end ===== " << *end << endl;//最后一个元素的下一个位置 array
::const_iterator cend = nArray.cend() - 1;//可用auto cout << "cend ==== " << *cend << endl;//最后一个元素的下一个位置 array
::reverse_iterator rbegin = nArray.rbegin();//可用auto cout << "begin === " << *rbegin << endl;//最后一个元素 array
::const_reverse_iterator crbegin = nArray.crbegin();//可用auto cout << "crbegin = " << *crbegin << endl;//最后一个元素 array
::reverse_iterator rend = nArray.rend();//可用auto cout << "rend ==== " << *(rend - 1) << endl;//第一个元素的前一个位置 array
::const_reverse_iterator crend = nArray.crend();//可用auto cout << "crend === " << *(crend - 1) << endl;//第一个元素的前一个位置 *begin = 67; //*cbegin = 25;//const类型的迭代器不能赋值 *end = 28; //*cend = 97;//const类型的迭代器不能赋值 for(auto &c: nArray) { cout << c << "\t"; } cout << endl; cout << endl;}int main(){ GetIterator(); cout << endl; cout << "Hello world" << endl; return 0;}

运行结果

begin和cbegin都是指向array的第一个元素,cbegin是常量迭代器,不能通过cbegin修改元素的值。

end和cend都是指array的最后一个元素的下一个位置,cend是常量迭代器,不能通过cend修改元素的值。

rbegin和crbegin都是指向array的最后一个元素,crbegin是常量迭代器,不能通过crbegin修改元素的值。

rend和crend都是指array的第一个元素的前一个位置,crend是常量迭代器,不能通过crend修改元素的值。

 

转载地址:http://lfiub.baihongyu.com/

你可能感兴趣的文章
【LEETCODE】118-Pascal's Triangle
查看>>
【LEETCODE】119-Pascal's Triangle II
查看>>
【LEETCODE】88-Merge Sorted Array
查看>>
【LEETCODE】19-Remove Nth Node From End of List
查看>>
【LEETCODE】125-Valid Palindrome
查看>>
【LEETCODE】28-Implement strStr()
查看>>
【LEETCODE】6-ZigZag Conversion
查看>>
【LEETCODE】8-String to Integer (atoi)
查看>>
【LEETCODE】14-Longest Common Prefix
查看>>
【LEETCODE】38-Count and Say
查看>>
【LEETCODE】278-First Bad Version
查看>>
【LEETCODE】303-Range Sum Query - Immutable
查看>>
【LEETCODE】21-Merge Two Sorted Lists
查看>>
【LEETCODE】231-Power of Two
查看>>
【LEETCODE】172-Factorial Trailing Zeroes
查看>>
【LEETCODE】112-Path Sum
查看>>
【LEETCODE】9-Palindrome Number
查看>>
【极客学院】-python学习笔记-Python快速入门(面向对象-引入外部文件-Web2Py创建网站)
查看>>
【LEETCODE】190-Reverse Bits
查看>>
【LEETCODE】67-Add Binary
查看>>