Angenommen, wir haben eine Sammlungsdatenstruktur von Daten vom Typ Ganzzahl. Auf unserer Standardeingabe stellen wir n Abfragen bereit. In jeder Abfrage (jeder Zeile) haben wir zwei Elemente. Der erste ist der Operator und der zweite das Element. So geht's –
Einfügen. Dadurch wird das Element in die Sammlung eingefügt und
entfernt. Dadurch wird das Element aus der Sammlung entfernt, sofern es vorhanden ist
Suchen. Dadurch wird die Sammlung nach dem Element durchsucht und „Ja“ angezeigt, falls vorhanden, andernfalls „Nein“.
Wenn die Eingabe also etwa n = 7 ist, dann ist die Abfrage = [[1,5],[1,8],[1,3],[2,8],[1,9], [3 ,8],[3,3]], dann lautet die Ausgabe [Nein, Ja], da 8 nicht in der Menge vorhanden ist, 3 jedoch schon.
Um dieses Problem zu lösen, führen wir die folgenden Schritte aus:
Sehen wir uns zum besseren Verständnis die folgende Implementierung an -
#include <iostream> #include <set> using namespace std; int main(){ set<int> s; set<int>::iterator it; int q,x; int qt; cin >> q; while(q--){ cin>>qt>>x; switch(qt){ case 1:s.insert(x); break; case 2:s.erase(x); break; case 3:it=s.find(x); if(it==s.end()) cout<<"No"<<endl; else cout<<"Yes"<<endl; break; } } return 0; }
7 1 5 1 8 1 3 2 8 1 9 3 8 3 3
No Yes
Das obige ist der detaillierte Inhalt vonC++-Programm zum Einfügen, Löschen und Suchen in gesetzten STL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!