unique函数用法

本文详细介绍了C++标准库中algorithm头文件内的unique函数,用于去除容器或数组中相邻重复元素。unique并不直接删除重复项,而是将不重复元素移到数组前面,并返回新的不重复序列末尾的地址。为了实现真正的去重,通常需要结合erase函数对数组进行排序和处理。文章通过代码示例展示了unique函数的使用方法和效果,强调了其返回值的重要性以及在去重过程中的作用。
摘要由CSDN通过智能技术生成

unique函数用法

unique包含在头文件

#include <algorithm>

函数作用:“去除”容器或数组中相邻元素之间重复出现的元素

unique函数的三个参数:

1、想要去重的数据集的起始地址

2、想要去重的最后一个元素的下一个元素的地址

3、比较函数(可以省略,也可以自定义,一般不太用到第三个参数)

返回值:返回的是去重后的不重复数列中最后一个元素的下一个元素的地址(注意是类似于0x的真正地址)

注意:

1、该函数并非真正地去除重复元素,只将不重复的元素排在数组最前边,但是去重后的数组最后的元素不变。(注意有一些说法是“去重之后是把重复的元素藏在了最后”, 这种说法是不准确的)

2、针对的是相邻元素,也就是说对于顺序错乱的数组,需要先进行排序,再配合erase后,才可以实现真正意义上的去重(也可以根据返回值枚举不重复的部分)

erase函数是针对容器的函数,不在algorithm库中,因此数组无法使用该函数。

时间复杂度:O(n)

代码案例

#include<iostream>
#include<algorithm>
using namespace std;

int main()
{
	int a[]={2,3,4,4,6};
	//sort(a,a+5);            //一般在使用unique之前都需要进行排序,由于这里是已经排好序的,所以不再使用 
	unique(a,a+5);           //使用unique函数对数组进行去重
	for(int i=0;i<5;i++)
	{
		cout<<"a["<<i<<"]="<<a[i]<<endl;
	}
	cout<<unique(a,a+5)<<endl;    //返回不重复数列中最后一个元素下一个元素的地址 
	cout<<a+4<<endl;              //输出a[4]的地址,发现与unique函数的返回值相同 
	cout<<"不重复数列的长度:"<<unique(a,a+5)-a<<endl;   //不重复序列的长度为4 
}

运行结果

在这里插入图片描述
通过运行结果可以看出,unique并不是真正地将重复元素进行了删除,而是不断将不重复的元素移动到数组的前面,最后返回的是返回的是去重后的不重复数列中最后一个元素的下一个元素的地址,如果需要计算该地址所对应的下标,则利用unique(a,a+n)-a即可

(关于unique配合erase函数来实现真正去重的内容,以后再进行补充,现在还没学到)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值