刚刚遇到了个问题,想了很久没想明白,现在终于明白了,罪魁祸首在于这个unique函数,只能去重相邻的重复元素,不能去除整队的重复元素!
unique()函数作用是“去掉”容器中相邻元素的重复元素,然后返回指向第一个重复元素的迭代器。unique()实质上是一个伪去除,它并不是真正把重复的元素删除,而是用不重复的元素把重复的元素覆盖了,所以总长度其实是不变的。
//#include<iostream>
//#include<vector>
//#include<algorithm>
//#include<cassert>
//要访问顺序容器和关联容器中的元素,需要通过“迭代器(iterator)”进行。
//迭代器是一个变量,相当于容器和操纵容器的算法之间的中介。
//迭代器可以指向容器中的某个元素,通过迭代器就可以读写它指向的元素。
//从这一点上看,迭代器和指针类似。
// vector 是向量类型,它可以容纳许多类型的数据,如若干个整数,所以称其为容器。
// vector 是C++ STL的一个重要成员,使用它时需要包含头文件:#include<vector>;
#include<bits/stdc++.h>
using namespace std;
int main()
{
vector<int> a={1,3,3,4,5,6,6,7};
// int a[]={1,3,3,4,5,6,6,7}; 使用此句报错,说明不能直接用于定义的数组类型。
vector<int>::iterator it_1 = a.begin();
vector<int>::iterator it_2 = a.end();
vector<int>::iterator new_end;
new_end = unique(it_1,it_2); //注意unique的返回值
//cout<<a[new_end],a.new_end,a::new_end<<endl; 都不对,无法输出。
a.erase(new_end,it_2);
cout<<"删除重复元素后的 a : ";
for(int i = 0 ; i < a.size(); i++)
cout<<a[i];
cout<<endl;
return0;
}