【C++】vector与迭代器的使用

【C++】vector与迭代器的使用



简介

本文是《C++ Primer》第五版关于vector和迭代器的读书笔记
!!!本文的源码均来自于《C++ Primer》第五版!!!(可能会稍作修改)
The source codes in this article are all from C++ Primer, The Fifth Edition


1. 标准库vector

vector:一个支持自动扩容,基于数组的容器
vector的初始化:截图来自于《C++ Primer》第五版,P87
在这里插入图片描述
vector的操作:截图来自于《C++ Primer》第五版,P91
在这里插入图片描述

2. 迭代器

迭代器(iterator):迭代器用于迭代访问标准库容器(例如vector)和string中的元素

2.1. 获取和使用迭代器

begin函数:基本所有标准库容器都有这个成员函数,它返回一个位于容器首个元素位置的迭代器,成为首迭代器
end函数:基本所有标准库容器都有这个成员函数,它返回一个位于容器末尾元素后一个位置的迭代器,成为尾迭代器(也就是说,end指向的内容不存在与容器中,它指向一个“尾后”的位置)

  • 容器为空:如果容器为空,那么首迭代器和尾迭代器都指向“尾后”
vector<int> v{1, 2, 3, 4, 5}
auto b = v.begin(), e = v.end();	// 创建两个迭代器,一个首迭代器,一个尾迭代器

迭代器运算符:截图来自于《C++ Primer》第五版,P96
在这里插入图片描述
解引迭代器访问&更改元素:用解引用符来访问迭代器指向的内容

string s1("ABC");
for (auto it = s1.begin(); it != s1.end(); it++)
{
	*it = tolower(*it);
}
cout << s1 << endl;		// 输出“abc”

箭头运算符访问成员:通过箭头运算符,我们可以直接访问迭代器指向内容的成员,而不用先解引再访问

vector<string> v1{"hello", "hi"};
auto it = v1.begin();

// 下面两行代码的功能是一样的
cout << (*it).size() << endl;	// 输出“5”
cout << it->size() << endl;		// 输出“5”

2.2. 迭代器的类型

iterator类型:可以读取并写入元素的迭代器,类似指针一样的存在
const_iterator类型:只能读取元素,不能写入元素的迭代器,类似指向常量的指针

  • 常量对象迭代器为const_iterator:若我们定义一个常量,并构造它的迭代器,那么auto会判断它为const_iterator
  • cbegin()和cend():与begin()和end()类似,唯一的不同点在于cbegin()和cend()返回的迭代器类型必为const_iterator
const vector<int> myVec;
auto it = myVec.begin();	// it的类型为const_iterator

迭代器失效:若在使用迭代器时,更改了容器的元素数量(加入或者删除元素),那么迭代器会失效,因为很有可能迭代器指向的内容将不复存在亦或者错位

2.3. 迭代器运算

迭代器常用运算:截图来自于《C++ Primer》第五版,P99
在这里插入图片描述
迭代器和二分查找:十分出名的二分查找法可以用迭代器快速实现,使用迭代器的好处在于不用处理元素下标,因为经验不丰富的程序员很容易在使用下标时发生下标超限(Index Out of Range)或者缓存溢出问题(Buffer Overflow)

  • 4
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中,vector是一种动态数组,它提供了一组方便的方法来管理和操作元素。而迭代器是一种用于遍历容器中元素的对象。vector迭代器可以用于访问和修改vector中的元素。 要使用vector迭代器,首先需要创建一个vector对象,并向其中添加一些元素。然后,可以使用begin()和end()方法来获取迭代器的起始位置和结束位置。 下面是一个使用vector迭代器的示例: ```cpp #include <iostream> #include <vector> int main() { std::vector<int> vec = {1, 2, 3, 4, 5}; // 使用迭代器遍历vector并输出元素 std::cout << "遍历vector输出元素:"; for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) { std::cout << *it << " "; } std::cout << std::endl; // 使用迭代器修改vector中的元素 std::cout << "修改前的vector:"; for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) { *it = *it * 2; std::cout << *it << " "; } std::cout << std::endl; // 使用迭代器插入新元素 std::cout << "插入新元素后的vector:"; vec.insert(vec.begin() + 2, 10); for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) { std::cout << *it << " "; } std::cout << std::endl; // 使用迭代器删除元素 std::cout << "删除元素后的vector:"; vec.erase(vec.begin() + 3); for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) { std::cout << *it << " "; } std::cout << std::endl; return 0; } ``` 输出结果: ``` 遍历vector输出元素:1 2 3 4 5 修改前的vector:2 4 6 8 10 插入新元素后的vector:2 4 10 6 8 10 删除元素后的vector:2 4 10 8 10 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值