C++ :STL 算法unique , unique_copy函数
来源:互联网 发布:psd头像源码怎么使用 编辑:程序博客网 时间:2024/05/16 17:46
一.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为空),那么会引发越界错误。
如果我们无法提前预分配内存,那么怎么办?使用插入迭代器
插入迭代器调用容器操作来向给定的容器的指定位置插入一个元素
- C++ :STL 算法unique , unique_copy函数
- C++ STL算法---unique , unique_copy函数
- c++ STL unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- C++ STL算法系列4---unique , unique_copy函数
- STL algorithm算法unique,unique_copy(58)
- STL算法之unique和unique_copy
- C++ STL 算法:删除算法(3)unique、unique_copy
- unique , unique_copy函数
- unique , unique_copy函数
- unique 与 unique_copy 函数
- leetcode-Contains Duplicate,STL unique,unique_copy等函数的使用
- unique函数和unique_copy函数
- (NYoj 171)聪明的kk --水dp
- php三天基础笔记(5)变量类型转换
- nginx rtmp module install compile
- 例题4-4 信息解码 UVa213
- openstack nova 源码解析 — Nova API 执行过程从(novaclient到Action)
- C++ :STL 算法unique , unique_copy函数
- net rtmp or hls play url
- Linux用ps命令查找进程PID再用kill命令终止进程的方法
- 【校内互测】Sunshine's book(找规律)
- Ubuntu 界面卡死的办法
- window 根据盘符获取磁盘号
- Python学习笔记五:数字和字符串
- 概率论中的建模思想
- js(javaScript)学习系列--基础