Partilhar via


set_difference

Junta todos os elementos que pertencem a um intervalo de origem classificados, mas não a um intervalo de origem, classificado em um único intervalo, classificado de destino, onde o critério de ordenação pode ser especificado por um predicado binário.

template<class InputIterator1, class InputIterator2, class OutputIterator> 
   OutputIterator set_difference( 
      InputIterator1 first1,  
      InputIterator1 last1, 
      InputIterator2 first2,  
      InputIterator2 last2,  
      OutputIterator result 
   ); 
template<class InputIterator1, class InputIterator2, class OutputIterator, class BinaryPredicate> 
   OutputIterator set_difference( 
      InputIterator1 first1,  
      InputIterator1 last1, 
      InputIterator2 first2,  
      InputIterator2 last2,  
      OutputIterator result,
      BinaryPredicate comp 
   );

Parâmetros

  • first1
    Um iterador de entrada que trata a posição do primeiro elemento na primeira de dois classificou os intervalos de origem a serem unidos e armazenado em um único intervalo que representa a diferença dos dois intervalos de origem.

  • last1
    Um iterador de entrada que trata à posição um passado o elemento o mais recente na primeira de dois classificou os intervalos de origem a serem unidos e armazenado em um único intervalo que representa a diferença dos dois intervalos de origem.

  • first2
    Um iterador de entrada que trata a posição do primeiro elemento em um segundo de dois intervalos de origem classificados consecutivos ser unido e armazenado em um único intervalo que representa a diferença dos dois intervalos de origem.

  • last2
    Um iterador de entrada que trata à posição um passado o elemento o mais recente em um segundo de dois intervalos de origem classificados consecutivos ser unido e armazenado em um único intervalo que representa a diferença dos dois intervalos de origem.

  • result
    Um iterador de saída que trata a posição do primeiro elemento no intervalo de destino onde os dois intervalos de origem devem ser unida em um único intervalo classificado que representa a diferença dos dois intervalos de origem.

  • comp
    Objeto definido pelo usuário da função de predicado que define no sentido a qual o elemento é maior que outro. O predicado binário usa dois argumentos e deve retornar true quando o primeiro elemento é menor que o segundo elemento e false de outra forma.

Valor de retorno

Um iterador de saída que trata à posição um passado o elemento o mais recente no intervalo classificado de destino que representa a diferença dos dois intervalos de origem.

Comentários

Os intervalos de origem classificados referenciados devem ser válidos; todos os ponteiros devem ser dereferenceable e dentro de cada sequência última posição deve ser possível acessá-lo do pela primeira incrementação.

O intervalo de destino não devem se sobrepor nenhum dos intervalos de origem e deve ser grande o suficiente para conter o primeiro intervalo de origem.

Os intervalos de origem classificados devem ser organizados cada um como um pré-requisito para o aplicativo do algoritmo de set_difference de acordo com o mesmo que classificam a ser usada pelo algoritmo para classificar os intervalos combinados.

A operação for estável porque a ordem relativa de elementos em cada intervalo é preservado no intervalo de destino. Os intervalos de origem não são alterados pela mesclagem do algoritmo.

Os tipos de valor dos iteradores de entrada precisam ser uma menos-do comparáveis ser ordenado, de modo que, dois elementos, se possa determinar o que são equivalentes (no sentido de que nenhum é menor que outro) ou que um é menor que outro. Isso resulta na ordem entre os elementos nonequivalent. Quando houver elementos equivalentes em ambos os intervalos de origem, os elementos no primeiro intervalo precedem os elementos do intervalo de segunda fonte no intervalo de destino. Se os intervalos de origem contêm duplicatas de um elemento de modo que haja mais no primeiro intervalo de origem de que no segundo, o intervalo de destino conterá o número pelo qual as ocorrências dos elementos no primeiro intervalo de origem excederem as ocorrências dos elementos no intervalo de segunda fonte.

A complexidade do algoritmo é linear com no máximo 2 * ( (last1 – first1) – (last2 – first2) ) – 1 comparações para intervalos de origem não vazios.

set_difference tem dois formulários relacionados:

Para obter informações sobre como essas funções se comportam, consulte Iteradores Verificados.

Exemplo

// alg_set_diff.cpp
// compile with: /EHsc
#include <vector>
#include <algorithm>
#include <functional>      // For greater<int>( )
#include <iostream>

// Return whether modulus of elem1 is less than modulus of elem2
bool mod_lesser (int elem1, int elem2 )
{
   if (elem1 < 0) 
      elem1 = - elem1;
   if (elem2 < 0) 
      elem2 = - elem2;
   return elem1 < elem2;
}

int main( )
{
   using namespace std;
   vector <int> v1a, v1b, v1 ( 12 );
   vector <int>::iterator Iter1a,  Iter1b, Iter1, Result1;

   // Constructing vectors v1a & v1b with default less-than ordering
   int i;
   for ( i = -1 ; i <= 4 ; i++ )
   {
      v1a.push_back(  i );
   }

   int ii;
   for ( ii =-3 ; ii <= 0 ; ii++ )
   {
      v1b.push_back(  ii  );
   }

   cout << "Original vector v1a with range sorted by the\n "
        <<  "binary predicate less than is  v1a = ( " ;
   for ( Iter1a = v1a.begin( ) ; Iter1a != v1a.end( ) ; Iter1a++ )
      cout << *Iter1a << " ";
   cout << ")." << endl;

   cout << "Original vector v1b with range sorted by the\n "
        <<  "binary predicate less than is  v1b = ( " ;
   for ( Iter1b = v1b.begin ( ) ; Iter1b != v1b.end ( ) ; Iter1b++ )
      cout << *Iter1b << " ";
   cout << ")." << endl;
   
   // Constructing vectors v2a & v2b with ranges sorted by greater
   vector <int> v2a ( v1a ) , v2b ( v1b ) ,  v2 ( v1 );
   vector <int>::iterator Iter2a, Iter2b, Iter2, Result2;
   sort ( v2a.begin ( ) , v2a.end ( ) , greater<int> ( ) );
   sort ( v2b.begin ( ) , v2b.end ( ) , greater<int> ( ) );

   cout << "Original vector v2a with range sorted by the\n "
        <<  "binary predicate greater is   v2a =  ( " ;
   for ( Iter2a = v2a.begin ( ) ; Iter2a != v2a.end ( ) ; Iter2a++ )
      cout << *Iter2a << " ";
   cout << ")." << endl;

   cout << "Original vector v2b with range sorted by the\n "
        <<  "binary predicate greater is   v2b =  ( " ;
   for ( Iter2b = v2b.begin ( ) ; Iter2b != v2b.end ( ) ; Iter2b++ )
      cout << *Iter2b << " ";
   cout << ")." << endl;

   // Constructing vectors v3a & v3b with ranges sorted by mod_lesser
   vector <int> v3a ( v1a ), v3b ( v1b ) ,  v3 ( v1 );
   vector <int>::iterator Iter3a,  Iter3b, Iter3, Result3;
   sort ( v3a.begin ( ) , v3a.end ( ) , mod_lesser );
   sort ( v3b.begin ( ) , v3b.end ( ) , mod_lesser  );

   cout << "Original vector v3a with range sorted by the\n "
        <<  "binary predicate mod_lesser is   v3a =  ( " ;
   for ( Iter3a = v3a.begin ( ) ; Iter3a != v3a.end ( ) ; Iter3a++ )
      cout << *Iter3a << " ";
   cout << ")." << endl;

   cout << "Original vector v3b with range sorted by the\n "
        <<  "binary predicate mod_lesser is   v3b =  ( " ;
   for ( Iter3b = v3b.begin ( ) ; Iter3b != v3b.end ( ) ; Iter3b++ )
      cout << *Iter3b << " ";
   cout << ")." << endl;

   // To combine into a difference in asscending
   // order with the default binary predicate less <int> ( )
   Result1 = set_difference ( v1a.begin ( ) , v1a.end ( ) ,
      v1b.begin ( ) , v1b.end ( ) , v1.begin ( ) );
   cout << "Set_difference of source ranges with default order,"
        << "\n vector v1mod =  ( " ;
   for ( Iter1 = v1.begin( ) ; Iter1 != Result1 ; Iter1++ )
      cout << *Iter1 << " ";
   cout << ")." << endl;

   // To combine into a difference in descending
   // order specify binary predicate greater<int>( )
   Result2 = set_difference ( v2a.begin ( ) , v2a.end ( ) ,
      v2b.begin ( ) , v2b.end ( ) ,v2.begin ( ) , greater <int> ( ) );
   cout << "Set_difference of source ranges with binary"
        << "predicate greater specified,\n vector v2mod  = ( " ;
   for ( Iter2 = v2.begin( ) ; Iter2 != Result2 ; Iter2++ )
      cout << *Iter2 << " ";
   cout << ")." << endl;

   // To combine into a difference applying a user
   // defined binary predicate mod_lesser
   Result3 = set_difference (  v3a.begin ( ) , v3a.end ( ) ,
      v3b.begin ( ) , v3b.end ( ) , v3.begin ( ) , mod_lesser );
   cout << "Set_difference of source ranges with binary "
        << "predicate mod_lesser specified,\n vector v3mod  = ( " ; ;
   for ( Iter3 = v3.begin( ) ; Iter3 != Result3 ; Iter3++ )
      cout << *Iter3 << " ";
   cout << ")." << endl;
}

Saída

Original vector v1a with range sorted by the
 binary predicate less than is  v1a = ( -1 0 1 2 3 4 ).
Original vector v1b with range sorted by the
 binary predicate less than is  v1b = ( -3 -2 -1 0 ).
Original vector v2a with range sorted by the
 binary predicate greater is   v2a =  ( 4 3 2 1 0 -1 ).
Original vector v2b with range sorted by the
 binary predicate greater is   v2b =  ( 0 -1 -2 -3 ).
Original vector v3a with range sorted by the
 binary predicate mod_lesser is   v3a =  ( 0 -1 1 2 3 4 ).
Original vector v3b with range sorted by the
 binary predicate mod_lesser is   v3b =  ( 0 -1 -2 -3 ).
Set_difference of source ranges with default order,
 vector v1mod =  ( 1 2 3 4 ).
Set_difference of source ranges with binarypredicate greater specified,
 vector v2mod  = ( 4 3 2 1 ).
Set_difference of source ranges with binary predicate mod_lesser specified,
 vector v3mod  = ( 1 4 ).

Requisitos

Cabeçalho: <algoritmo>

Namespace: std

Consulte também

Referência

Biblioteca de Modelos Padrão