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