C++ :STL 算法unique , unique_copy函数

一.unique函数《#include < algorithm >》

在STL中unique函数是一个去重函数, unique的功能是去除相邻的重复元素(只保留一个),看一下效果:
这里写图片描述
可以看到元素的个数没有改变,但顺序改变,后面的300,400在原先的位置被保留下;
一般用法:
1.先排序sort(s.begin(), s.end());
2.去重 auto end_unique = unique(s.begin(), s.end());,返回一个迭代器(例如图中,返回的迭代器指向第二个300的位置)
3. 删除不需要的 s.erase(end_unique, s.end()); (将图中后面的300,400删除)

二、unique_copy函数

unique_copy根据字面意思就是去除重复元素再执行copy运算;
例如:编写程序使用unique_copy将一个list对象中不重复的元素赋值到一个空的vector对象

list<int> ilst{5 , 2 , 2 , 2 , 100 , 5 , 2};
vector<int> ivec;
//将list对象ilst中不重复的元素复制到空的vector对象ivec中
//sort(ilst.begin() , ilst.end());  //不能用此种排序,会报错,一般list有自己的排序算法
ilst.sort();  //在进行复制之前要先排序,切记
unique_copy(ilst.begin() , ilst.end() , back_inserter(ivec));

注意代码中back_inserter(ivec)插入迭代器(将容器ivec与之绑定) C++primer P358
什么时候使用插入迭代器:
当我们调用copy函数的时候,要确保目标容器具有足够大的空间,例如:

//将other的所有元素拷贝到以coll.begin()为起始地址的位置
copy(other.begin(), other.end(), coll.begin());
如果之前没有为coll分配好内存(coll为空),那么会引发越界错误。

如果我们无法提前预分配内存,那么怎么办?使用插入迭代器
插入迭代器调用容器操作来向给定的容器的指定位置插入一个元素

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值