4 votes

Algorithme d'union d'ensembles utilisant un vecteur en C++

J'utilise seulement std::vector dans ce problème, et je peux garantir l'absence de doublons dans chaque vecteur (mais il n'y a pas d'ordre dans chaque vecteur). Comment puis-je réunir les vecteurs dont je dispose ?

Exemple :

Si j'ai les vecteurs suivants...

1
1
3 2
5
5 4
2
4
4 2

Après l'union, il ne devrait rester que deux vecteurs :

1
2 3 4 5

Encore une fois, je n'utilise que le vecteur, std::set n'est pas autorisé.

14voto

shivakumar Points 1595

Vous pouvez utiliser l'algorithme std::set_union.

int first[] = {5,10,15,20,25};
  int second[] = {50,40,30,20,10};
  std::vector<int> v(10);                      // 0  0  0  0  0  0  0  0  0  0
  std::vector<int>::iterator it;

  std::sort (first,first+5);     //  5 10 15 20 25
  std::sort (second,second+5);   // 10 20 30 40 50

  it=std::set_union (first, first+5, second, second+5, v.begin());
                                               // 5 10 15 20 25 30 40 50  0  0
  v.resize(it-v.begin());                      // 5 10 15 20 25 30 40 50

Référer : http://www.cplusplus.com/reference/algorithm/set_union/

1voto

Grigor Gevorgyan Points 3863

Triez les vecteurs, puis fusionnez-les comme dans mergesort, mais n'insérez pas les doublons.

vector<int> a, b, c;
sort( a.begin(), a.end());
sort( b.begin(), b.end());
int i = 0, j = 0;
while( i < a.size() && j < b.size())
if( a[ i ] == b[ j ] )
{
   c.push_back( a[ i ] );
   ++i, ++j;
}
else if( a[ i ] < b[ j ] )
   c.push_back( a[ i++ ] );
else 
   c.push_back( b[ j++ ] );

while( i < a.size()) c.push_back( a[ i++ ] );
while( j < b.size()) c.push_back( b[ j++ ] );

0voto

Khaled A Khunaifer Points 2332

Voici mon code :

template<class T> bool vectorExist (vector<T> c, T item)
{
    return (std::find(c.begin(), c.end(), item) != c.end());
}

template<class T> vector<T> vectorUnion (vector<T> a, vector<T> b)
{
    vector<T> c;

    std::sort(a.begin(), a.end());
    std::sort(b.begin(), b.end());

    auto i = a.begin();
    auto j = b.begin();

    while (i != a.end() || j != b.end())
    {
        if (j == b.end() || *i < *j)
        {
            if(!exist(c,*i)) c.insert(*i);
            i++;
        }
        else
        {
            if(!exist(c,*j)) c.insert(*j)
            j++;
        }
    }

    return c;
}

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X