C++中vector、unordered_map等不同容器的迭代器中end()的指向问题

本文探讨C++中vector和unordered_map等容器的迭代器end()的特性,强调end()并不指向最后一个元素,而是指向其后的位置。通过示例代码解释,说明遍历过程中不会访问到end()所指位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++中vector、unordered_map等不同容器的迭代器中end()的指向问题

前言

今天刷力扣看见这样一行代码if (mp.find(x - 1) != mp.end()),我一直想为什么要判断和最后一个元素等不等呢?纠结了好久,后面才发现我对end()的指向问题一直搞错了,我一直以为指向的是末尾最后一个元素(就像begin()一样指向一个元素)。

正文

通俗的讲end()并没有指向一个元素,或者可以说是指向一个空的位置,即end()函数返回的不是指向最后一个元素的迭代器,而是指向最后一个元素后面的位置的迭代器。在遍历迭代器的过程中也不会遍历到end()。以下面的代码为例,

	unordered_map<int, int> mmap{
    {
   
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值