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; }