c++ primer 3rd 练习223 总结

本文探讨了一段使用迭代器寻找向量中最小元素的代码,并指出了其中存在的问题。特别是针对循环边界处理不当可能导致的越界错误进行了分析,提出了正确的循环终止条件。

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

 

题目是

已知下列函数声明 请实现 min()的函数体 它查找并返回 vec 的最小元素 要求首先使 
用 索引 vec 中元素的 for 循环 来实现min() 然后 再使用 通过迭代器遍历vec 的for 
循环 来实现 min() 

 

上面的代码是用iterator来实现,有什么问题没有呢?如果认为没有,可以再仔细的看看。

 

 

上面的代码因为用了‘while'与后缀的'++'这两个keyword,那就要理解这两个东东咯

在循环的最后一次,iter = vec.end() - 1, 这个时候判断条件成立,然后iter++, 在循环体内iter = vec.end(), 已经越界了

 

所以此句while应该为

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值