博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++ STL算法系列4---unique , unique_copy函数
阅读量:6682 次
发布时间:2019-06-25

本文共 3236 字,大约阅读时间需要 10 分钟。

 

 一.unique函数

类属性算法unique的作用是从输入序列中“删除”所有相邻的重复元素

该算法删除相邻的重复元素,然后重新排列输入范围内的元素,并且返回一个迭代器(容器的长度没变,只是元素顺序改变了),表示无重复的值范围得结束。

1 // sort words alphabetically so we can find the duplicates  2 sort(words.begin(), words.end());  3      /* eliminate duplicate words:  4       * unique reorders words so that each word appears once in the  5       *    front portion of words and returns an iterator one past the  6 unique range;  7       * erase uses a vector operation to remove the nonunique elements  8       */  9  vector
::iterator end_unique = unique(words.begin(), words.end()); 10 words.erase(end_unique, words.end());
在STL中unique函数是一个去重函数, unique的功能是去除相邻的重复元素(只保留一个),其实它并不真正把重复的元素删除,是把重复的元素移到后面去了,然后依然保存到了原数组中,然后 返回去重后最后一个元素的地址,因为unique去除的是相邻的重复元素,所以一般用之前都会要排一下序。

若调用sort后,vector的对象的元素按次序排列如下:

sort  jumps  over quick  red  red  slow  the  the turtle

则调用unique后,vector中存储的内容是:

 

 

 

 

 

 

注意,words的大小并没有改变,依然保存着10个元素;只是这些元素的顺序改变了。调用unique“删除”了相邻的重复值。给“删除”加上引号是因为unique实际上并没有删除任何元素,而是将无重复的元素复制到序列的前段,从而覆盖相邻的重复元素。unique返回的迭代器指向超出无重复的元素范围末端的下一个位置。

注意:算法不直接修改容器的大小。如果需要添加或删除元素,则必须使用容器操作。

example:

 

1 #include 
2 #include
3 #include
4 #include
5 #include
6 #include
7 using namespace std; 8 9 int main()10 {11 //cout<<"Illustrating the generic unique algorithm."<
vector1;15 for (int i=0;i
::iterator new_end;19 new_end=unique(vector1.begin(),vector1.end()); //"删除"相邻的重复元素20 assert(vector1.size()==N);21 22 vector1.erase(new_end,vector1.end()); //删除(真正的删除)重复的元素23 copy(vector1.begin(),vector1.end(),ostream_iterator
(cout," "));24 cout<

 

运行结果为:

 

 

二、unique_copy函数

算法标准库定义了一个名为unique_copy的函数,其操作类似于unique。

唯一的区别在于:前者接受第三个迭代器实参,用于指定复制不重复元素的目标序列。

unique_copy根据字面意思就是去除重复元素再执行copy运算。

编写程序使用unique_copy将一个list对象中不重复的元素赋值到一个空的vector对象中。

1 //使用unique_copy算法 2 //将一个list对象中不重复的元素赋值到一个空的vector对象中 3 #include
4 #include
5 #include
6 #include
7 using namespace std; 8 9 int main()10 {11 int ia[7] = {
5 , 2 , 2 , 2 , 100 , 5 , 2};12 list
ilst(ia , ia + 7);13 vector
ivec;14 15 //将list对象ilst中不重复的元素复制到空的vector对象ivec中16 //sort(ilst.begin() , ilst.end()); //不能用此种排序,会报错17 ilst.sort(); //在进行复制之前要先排序,切记18 unique_copy(ilst.begin() , ilst.end() , back_inserter(ivec));19 20 //输出vector容器21 cout<<"vector: "<
::iterator iter = ivec.begin() ; iter != ivec.end() ; ++iter)23 cout<<*iter<<" ";24 cout<

 假如

list
ilst(ia , ia + 7);改为:vector
ilst(ia , ia + 7);

则排序时可用:

sort(ilst.begin() , ilst.end());

 这里要注意list和vector的排序用什么方法。

《Effective STL》里这些话可能有用处: item 31      “我们总结一下你的排序选择:    ● 如果你需要在vector、string、deque或数组上进行完全排序,你可以使用sort或stable_sort。    ● 如果你有一个vector、string、deque或数组,你只需要排序前n个元素,应该用partial_sort。    ● 如果你有一个vector、string、deque或数组,你需要鉴别出第n个元素或你需要鉴别出最前的n个元素,而不用知道它们的顺序,nth_element是你应该注意和调用的。    ● 如果你需要把标准序列容器的元素或数组分隔为满足和不满足某个标准,你大概就要找partition或stable_partition。    ● 如果你的数据是在list中,你可以直接使用partition和stable_partition,你可以使用list的sort来代替sort和stable_sort。如果你需要partial_sort或nth_element提供的效果,你就必须间接完成这个任务,但正如我在上面勾画的,会有很多选择。      另外,你可以通过把数据放在标准关联容器中的方法以保持在任何时候东西都有序。你也可能会考虑标准非STL容器priority_queue,它也可以总是保持它的元素有序。

转载地址:http://rbxao.baihongyu.com/

你可能感兴趣的文章
B/S结构 进销存 客户管理 人资管理系统
查看>>
iOS 学习资料整理 {非常有用,强烈推荐}
查看>>
Linux上安装使用boost入门指导
查看>>
Tomcat去除项目名
查看>>
spring boot Controller不起作用的解决方案
查看>>
分布式ID生成算法总结
查看>>
目录管理和文件管理
查看>>
广播事件的两种类型。
查看>>
cmd进入控制Mysql&出现乱码的问题
查看>>
POJ 2407 Relatives 题解《挑战程序设计竞赛》
查看>>
关于那些最好玩的户外APP合集下(适合资深驴友、牛逼设计狮、装逼攻城狮)...
查看>>
syslog本地和远程日志分离
查看>>
ISCSI共享存储配置跟parted命令简述
查看>>
SysUtils.WrapText - 换行
查看>>
静态路由与浮动路由的配置
查看>>
实现一个日期类
查看>>
安装Oracle 11g R2 单实例数据库(非asm)
查看>>
linux-wget命令笔记
查看>>
Java 内存分配全面浅析
查看>>
JVM(6)之 二次标记
查看>>