在C++中的向量向量上使用"unique()"

Sag*_*gar 3 c++ algorithm stl vector unique

我希望这不是一个重复的问题,但如果是,请随意指出我正确的方向.

我有一个vector<vector<int> >.

有可能unique()在这上面使用吗?就像是:

vector<vector<int> > myvec;
//blah blah do something to myvec
vector<vector<int> >::interator it = unique(myvec.begin(), myvec.end());
Run Code Online (Sandbox Code Playgroud)

请问范围myvec.begin()it是唯一的?

小智 5

是的,只要您的矢量已排序.有关详细信息,请参阅unique() STL文档.

以下是一个用法示例:

#include <vector>
#include <string>
#include <algorithm>
#include <string>
#include <iostream>

using namespace std;

int main ()
{
    vector< vector<string> > v;

    v.push_back (vector<string> ());
    v.back ().push_back ("A");

    v.push_back (vector<string> ());
    v.back ().push_back ("A");

    v.push_back (vector<string> ());
    v.back ().push_back ("B");

    for (vector< vector<string> >::iterator it = v.begin (); it != v.end (); ++it)
        for (vector<string>::iterator j = it->begin (), j_end = it->end (); j != j_end; ++j)
            cout << *j << endl;

    cout << "-------" << endl;

    vector< vector<string> >::iterator new_end = unique (v.begin (), v.end ());
    for (vector< vector<string> >::iterator it = v.begin (); it != new_end; ++it)
        for (vector<string>::iterator j = it->begin (), j_end = it->end (); j != j_end; ++j)
            cout << *j << endl;
}
Run Code Online (Sandbox Code Playgroud)