STL - set_intersection

Dal quinto capitolo di Designing Components with the C++ STL, di Ulrich Breymann. Algoritmi standard.

Sezione dedicata operazioni insiemistiche su strutture ordinate.

5.6.3: set_intersection

La set_intersection() costruisce una sequenza che contiene gli elementi presenti in entrambe le sequenze ordinate passate in input. Dunque costruisce l'intersezione tra le due sequenze originali.

Ecco un esempio:

#include<iostream>
#include<algorithm>
#include<set>
#include<vector>

using namespace std;

void dump(const set<int>& v) {
set<int>::const_iterator it = v.begin();
while (it != v.end()) {
cout << *it++ << ' ';
}
cout << endl;
}

int main() {
int v1[] = {0, 1, 2, 3, 4, 5, 7, 99, 13};
int v2[] = {-2, 5, 12, 7, 33};

set<int> s1(v1, v1 + sizeof v1 / sizeof *v1);
set<int> s2(v2, v2 + sizeof v2 / sizeof *v2);

set<int> result;

set_intersection(s1.begin(), s1.end(), s2.begin(), s2.end(),
inserter(result, result.begin()));

cout << "The intersection between: ";
dump(s1);
cout << "and: ";
dump(s2);
cout << "yields to: ";
dump(result);
}

Nessun commento:

Posta un commento