C++ iterator 2

更加有效的迭代器

1、插入迭代器

2、流迭代器

3、方向迭代器

4、移动迭代器(C++11)

 

#include <iostream>  
#include <unordered_set>
#include <string>
#include <vector>
#include<iterator>

using namespace std;


int main()
{
	
	// insert iteratot
	vector<int> vec1={1,2,3};
	vector<int>vec2 = {1,2,3,4,5,6,7,8};
	auto it = find(vec2.begin(), vec2.end(),1);//
	insert_iterator<vector<int>> it1 (vec2,it);// 指向vec2  的it 位置
	copy(vec1.begin(),vec1.end(),it1);//vec1的所有元素都插入到it 前面

	//stream iterator
	vector<string>vec3;
	copy(istream_iterator<string>(cin), istream_iterator<string>(),back_inserter(vec3));//将cin 中的字符插入到vec3的结尾
	copy(vec3.begin(),vec3.end(), ostream_iterator<string>(cout," ")); //将vec3的元素输出

	//reverse iterator
	vector<int>vec5 = {4,5,6};
	for (auto it = vec5.rbegin(); it != vec5.rend(); it++)
	{
		cout << *it << endl;
	}

	system("pause");
	return 0;

}

 

C++中,使用迭代器遍历容器是一种常见的操作。引用中给出了一个使用std::vector的迭代器遍历容器的例子。在这个例子中,我们首先声明一个迭代器变量it,初始化为容器的begin()函数返回的迭代器,然后通过比较it是否等于容器的end()函数返回的迭代器来判断是否遍历到了容器的末尾。在每次循环中,我们通过*it来访问迭代器指向的元素,并将其输出到屏幕上。 在引用中,还提到了迭代器的不同类型。在声明迭代器时,可以使用iterator来读写容器的元素,也可以使用const_iterator来只读容器的元素,不能修改容器中的元素。此外,还可以使用reverse_iterator来逆序迭代容器。 如果你想遍历一个vector容器的元素,你可以使用如下的方式来编写迭代器的循环:<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C++ 迭代器iterator](https://blog.csdn.net/2201_75772333/article/details/130618990)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [C++迭代器(iterator)](https://blog.csdn.net/weixin_47700137/article/details/119251703)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xieshangxin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值