Weiterleitungsliste in C++ | Set 1 (Einführung und wichtige Funktionen) Weitere Funktionen werden in diesem Artikel besprochen. Einige der Vorgänge außer Einfügungen und Löschungen, die in Vorwärtslisten verwendet werden können, sind wie folgt:
1. verschmelzen() :- Diese Funktion wird verwendet, um eine Weiterleitungsliste mit einer anderen zusammenzuführen. Wenn beide Listen sortiert sind, wird auch die resultierende zurückgegebene Liste sortiert.
2. Operator '=' :- Dieser Operator kopiert eine Weiterleitungsliste in eine andere. Die in diesem Fall erstellte Kopie ist eine tiefe Kopie.
CPP// C++ code to demonstrate the working of // merge() and operator= #include #include using namespace std; int main() { // Initializing 1st forward list forward_list<int> flist1 = {1 2 3}; // Declaring 2nd forward list forward_list<int> flist2; // Creating deep copy using '=' flist2 = flist1; // Displaying flist2 cout << 'The contents of 2nd forward list' ' after copy are : '; for (int &x : flist2) cout << x << ' '; cout << endl; // Using merge() to merge both list in 1 flist1.merge(flist2); // Displaying merged forward list // Prints sorted list cout << 'The contents of forward list ' 'after merge are : '; for (int &x : flist1) cout << x << ' '; cout << endl; return 0; }
Ausgabe:
endliche Zustandsmaschine
The contents of 2nd forward list after copy are : 1 2 3 The contents of forward list after merge are : 1 1 2 2 3 3
Zeitkomplexität: O(1)
Hilfsraum: O(1)
3. Sortieren() :- Mit dieser Funktion wird die Vorwärtsliste sortiert.
4. einzigartig() :- Diese Funktion löscht das mehrfache Vorkommen einer Zahl und gibt eine Vorwärtsliste mit eindeutigen Elementen zurück. Damit diese Funktion erfolgreich ausgeführt werden kann, muss die Weiterleitungsliste sortiert sein.
CPP// C++ code to demonstrate the working of // sort() and unique() #include #include // for sort() and unique() using namespace std; int main() { // Initializing 1st forward list forward_list<int> flist1 = {1 2 3 2 3 3 1}; // Sorting the forward list using sort() flist1.sort(); // Displaying sorted forward list cout << 'The contents of forward list after ' 'sorting are : '; for (int &x : flist1) cout << x << ' '; cout << endl; // Use of unique() to remove repeated occurrences flist1.unique(); // Displaying forward list after using unique() cout << 'The contents of forward list after ' 'unique operation are : '; for (int &x : flist1) cout << x << ' '; cout << endl; return 0; }
Ausgabe:
Boolescher Wert zum Stringen
The contents of forward list after sorting are : 1 1 2 2 3 3 3 The contents of forward list after unique operation are : 1 2 3
Zeitkomplexität: O(1)
Hilfsraum: O(1)
5. umkehren() :- Diese Funktion wird verwendet, um die Vorwärtsliste umzukehren.
6. tauschen() :- Diese Funktion tauscht den Inhalt einer Weiterleitungsliste mit einer anderen aus.
CPP// C++ code to demonstrate the working of // reverse() and swap() #include #include // for reverse() and swap() using namespace std; int main() { // Initializing 1st forward list forward_list<int> flist1 = {1 2 3}; // Initializing 2nd forward list forward_list<int> flist2 = {4 5 6}; // Using reverse() to reverse 1st forward list flist1.reverse(); // Displaying reversed forward list cout << 'The contents of forward list after' ' reversing are : '; for (int &x : flist1) cout << x << ' '; cout << endl << endl; // Displaying forward list before swapping cout << 'The contents of 1st forward list ' 'before swapping are : '; for (int &x : flist1) cout << x << ' '; cout << endl; cout << 'The contents of 2nd forward list ' 'before swapping are : '; for (int &x : flist2) cout << x << ' '; cout << endl; // Use of swap() to swap the list flist1.swap(flist2); // Displaying forward list after swapping cout << 'The contents of 1st forward list ' 'after swapping are : '; for (int &x : flist1) cout << x << ' '; cout << endl; cout << 'The contents of 2nd forward list ' 'after swapping are : '; for (int &x : flist2) cout << x << ' '; cout << endl; return 0; }
Ausgabe:
Samen vs. Sporen
The contents of forward list after reversing are : 3 2 1 The contents of 1st forward list before swapping are : 3 2 1 The contents of 2nd forward list before swapping are : 4 5 6 The contents of 1st forward list after swapping are : 4 5 6 The contents of 2nd forward list after swapping are : 3 2 1
Zeitkomplexität: O(1)
Hilfsraum: O(1)
7. klar() :- Diese Funktion löscht den Inhalt der Weiterleitungsliste. Nach dieser Funktion wird die Weiterleitungsliste leer.
8. leer() :- Diese Funktion gibt true zurück, wenn die Liste leer ist, andernfalls false.
Hashset vs. HashmapCPP
// C++ code to demonstrate the working of // clear() and empty() #include #include // for clear() and empty() using namespace std; int main() { // Initializing forward list forward_list<int> flist1 = {1 2 3}; // Displaying forward list before clearing cout << 'The contents of forward list are : '; for (int &x : flist1) cout << x << ' '; cout << endl; // Using clear() to clear the forward list flist1.clear(); // Displaying list after clear() performed cout << 'The contents of forward list after ' << 'clearing are : '; for (int &x : flist1) cout << x << ' '; cout << endl; // Checking if list is empty flist1.empty() ? cout << 'Forward list is empty' : cout << 'Forward list is not empty'; return 0; }
Ausgabe:
The contents of forward list are : 1 2 3 The contents of forward list after clearing are : Forward list is empty
Zeitkomplexität: O(1)
Hilfsraum: O(1)
Aktuelle Artikel auf forward_list