STL插入迭代器之copy函数、back_inserter函数、front_inserter函数及reverse函数解析

在C++中,STL算法(algorithms)接口提供了 Copy、reverse等函数方便用户对数据进行操作;

Gogogogo

1、 Reverse函数
首先,该函数存在于algorithm.h头文件中,使用该函数时务必包含该h文
reverse函数功能是将字符串、数组、容器等中的数据元素进行反转。
Notice整个操作区间是[first,last),—>也符合C++的编程习惯,基本都是左闭右开

reverse函数无返回值

string a = "Reverse";
reverse(a.begin(), a.end());

2、Copy函数

该函数提供了数据的复制功能,相比利用for循环逐一复制,效率更快。

如果用户需要将数据复制到容器前端,在保证不溢出的前提下,使用copy函数
若用户需要将数据复制到容器的后端,则使用back_inserter()函数,此时超出size的话,会默认申请空间。
copy

vector<int> src = { 0, 1, 2, 3, 4 };
vector<int> dst(8, -1);
std::copy(src.begin(), src.end(), dst.begin());

上述结果: 0 1 2 3 4 -1 -1 ,size为8,超出元素被舍弃掉。

back_insert():

vector<int> vct1 = {1,2,3,4,5,6};
vector<int> vct3={-1};
copy(vct1.begin(), vct1.end(), back_inserter(vct3));

输出结果:-1 1 2 3 4 5 6,确保了容器有足够的大小来容纳每个元素。

如果使用front_inserter函数,正如该函数名一样,每次的插入都会是在front,即前沿。
延续相同的例子

copy(vct1.begin(), vct1.end(), front_inserter(vct3));

输出结果:6 5 4 3 2 1 -1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值