[C++]迭代器

目录

一、迭代器

二、迭代器与算法配合使用

三、四种迭代器

[3.1、iterator 普通对象正向迭代器](#3.1、iterator 普通对象正向迭代器)

[3.2、const_iterator const对象正向迭代器](#3.2、const_iterator const对象正向迭代器)

[3.3、reverse_iterator 普通对象反向迭代器](#3.3、reverse_iterator 普通对象反向迭代器)

[3.4、const_reverse_iterator const对象反向迭代器](#3.4、const_reverse_iterator const对象反向迭代器)

一、迭代器

**迭代器是类似指针一样的抽象数据类型,迭代器提供了统一的方式来查看和修改容器中的数据。**对于不同的容器,迭代器的具体实现可能不同(可能是指针,也可能是类对象)。begin() 返回指向容器第一个元素的迭代器,end() 返回指向容器最后一个元素之后位置的迭代器,迭代器范围是左闭右开区间 [begin, end)

二、迭代器与算法配合使用

算法通过迭代器访问和操作容器中的元素,而无需知道容器的具体类型。C++标准库中的 std::reverse 函数模板,它展示了如何通过函数模板实现泛型算法,使其适用于不同的容器。

复制代码
//迭代器和算法配合使用
int main()
{
	string s1("hello world");
	reverse(s1.begin(), s1.end());

	string::iterator it = s1.begin();
	while (it != s1.end())
	{
		cout << *it << " ";
		it++;
	}
	cout << endl;

	vector<int> v1;
	v1.push_back(1);
	v1.push_back(2);
	v1.push_back(3);
	v1.push_back(4);

	reverse(v1.begin(), v1.end());

	vector<int>::iterator vit = v1.begin();
	while (vit != v1.end())
	{
		cout << *vit << " ";
		vit++;
	}
	cout << endl;
	return 0;
}
//输出结果
//d l r o w   o l l e h
//4 3 2 1

三、四种迭代器

3.1、iterator 普通对象正向迭代器

复制代码
	string s1("hello world");
	//正向迭代器->可以读 可以修改 普通对象可以调用
	string::iterator it = s1.begin();
	while (it != s1.end())
	{
		(*it)++;
		cout << *it << " ";
		it++;
	}
	cout << endl;
//运行结果i f m m p ! x p s m e

3.2、const_iterator const对象正向迭代器

复制代码
void Func(const string& s)
{
	//const对象正向迭代器->只能读 不能修改 const对象调用
	string::const_iterator const_it = s.begin();
	while (const_it != s.end())
	{
		//*const_it++;//error const对象的正向迭代器只能读,不能修改
		cout << *const_it << " ";
		const_it++;
	}
	cout << endl;
}
int main()
{
	string s1("hello world");
	Func(s1);
}
//输出结果h e l l o   w o r l d

3.3、reverse_iterator 普通对象反向迭代器

复制代码
	//反向迭代器->可以读 可以修改 普通对象可以调用
	string s1("hello world");	
    string::reverse_iterator rit = s1.rbegin();
	while (rit != s1.rend())
	{
		(*rit)++;
		cout << *rit << " ";
		rit++;
	}
	cout << endl;
//输出结果 e m s p x ! p m m f i

3.4、const_reverse_iterator const对象反向迭代器

复制代码
void Func(const string& s)
{
	////const对象反向迭代器 const对象的反向迭代器只能读,不能修改
	string::const_reverse_iterator const_rit = s.rbegin();
	while (const_rit != s.rend())
	{
		////*const_rit += 3;//error 不能修改
		cout << *const_rit << " ";
		const_rit++;
	}
	cout << endl;
}
int main()
{
	string s1("hello world");
	Func(s1);
}
//输出结果d l r o w   o l l e h
相关推荐
AI进化营-智能译站14 分钟前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust17 分钟前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
Morwit24 分钟前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展
qeen8736 分钟前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
莎士比亚的文学花园39 分钟前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
图码1 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
U盘失踪了1 小时前
python curl转python脚本
开发语言·chrome·python
charlie1145141911 小时前
Linux 字符设备驱动:cdev、设备号与设备模型
linux·开发语言·驱动开发·c
handler011 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
FQNmxDG4S1 小时前
Java泛型编程:类型擦除与泛型方法的应用场景
java·开发语言·python