迭代器

迭代器的分类

在这里插入图片描述
上面是基本的容器,根据不同容器的特性的区别,迭代器iterator根据访问的特性可以分为 五大类:

  • 最基本的是:random_access_iterator,这种随机访问证明是可以在iterator上实现随机跳转(+n).例如对于array,vector,deque这三种。虽然stack和queue是封装了deque,但是C++是不给stack和queue提供迭代器。
  • 在随机访问的基础上,定义了双向的iterator,这种双向的iterator可以++、–,对于list(双向链表),hash_table(底层的拉链是双向链表),set/multiset/map/multimap底层是红黑树,因此也应该是双向访问。
  • 在双向的iterator上,存在单向的iterator,也就是只能单向移动的iterator,例如forward-list.
  • 还存在两种特殊的iterator:input和output。

在这里插入图片描述

在这里插入图片描述

两种特殊的迭代器的声明。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值