Qt中没有unique函数,只能用遍历的方法了,代码如下:
#include <QApplication>
#include <QDebug>
#include <QString>
#include <QVector>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QVector<QString> strVec;
strVec.append("1");
strVec.append("2");
strVec.append("3");
strVec.append("4");
strVec.append("5");
strVec.append("3");
strVec.append("5");
for(int i=0;i<strVec.size();i++){
for(int j=i+1;j<strVec.size();j++){
if(strVec[j]==strVec[i]){
strVec.remove(i);
i--;
}
}
}
return a.exec();
}
未去除前的截图:
去除后的截图:
而在标准C++中有一个unique函数,他能把(相邻)重复的值放到容器的最后【所以这个要先排序】,并且返回一个iterator,这个iterator为开始重复的位置。
源码如下:
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
using namespace std;
void main(){
vector<string> strVec;
strVec.push_back("1");
strVec.push_back("2");
strVec.push_back("3");
strVec.push_back("4");
strVec.push_back("5");
strVec.push_back("3");
strVec.push_back("5");
sort(strVec.begin(),strVec.end());
vector<string>::iterator it=unique(strVec.begin(),strVec.end());
strVec.erase(it,strVec.end());
getchar();
}
去除前的截图:
去除后的截图:
qu'c