C++中unique函數


介紹

unique是STL比較實用的一個函數。用於“去除”容器內相鄰的重復的元素(只保留一個)。這里說的去除並不是真正將容器內的重復元素刪去,只是把重復的元素移到容器最后,但是依然在容器內。 對於數組而言返回去重后最后一個元素的指針,而其他容器則是返回去重后最后一個元素的迭代器。

用法舉例

因為是去除相鄰的重復元素,因此通常使用前容器應該要是有序的。

數組

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
	int a[6] = {1,1,4,6,6,7};
	int *p = unique(a,a+6);
	cout << &a[4] << endl;
	cout << p << endl;
	cout << p - a <<endl;
	for(int i = 0;i < p-a;i++)
	{
		cout << a[i] << endl;
	}
	return 0;
}

vector

要想真正去除重復元素還需要使用erase()函數

#include <iostream>
#include <algorithm>
#include <vector> 
using namespace std;
int main()
{
	vector<int> v;
	v.push_back(1);
	v.push_back(1);
	v.push_back(4);
	v.push_back(6);
	v.push_back(6);
	v.push_back(7);
	vector<int>::iterator it = unique(v.begin(),v.end());
	cout<< v.size() <<endl;
	v.erase(it,v.end());
	for(it = v.begin();it != v.end();it++)
	{
		cout << *it << " ";	
	} 
	return 0;
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM