C++ STL

Mobile Features AB

In dieser Einführung dreht sich alles um die C++ Standard Template Library (STL). Hier findest du Antworten auf die Fragen: Was ist die C++ STL? Welche Grundbegriffe und Konzepte solltest du kennen? Welche STL-Container sind in C++ verfügbar und wofür werden sie verwendet? Darüber hinaus werden die Datenstrukturen der C++ STL beleuchtet. Praktische Anwendungsfälle und Coding-Herausforderungen machen dir die Komplexität und gleichzeitig die Anwendungsfreundlichkeit der C++ STL deutlich. Fehlerbehebung und Optimierung in C++ STL runden das Thema ab.

Los geht’s

Lerne mit Millionen geteilten Karteikarten

Leg kostenfrei los

Schreib bessere Noten mit StudySmarter Premium

PREMIUM
Karteikarten Spaced Repetition Lernsets AI-Tools Probeklausuren Lernplan Erklärungen Karteikarten Spaced Repetition Lernsets AI-Tools Probeklausuren Lernplan Erklärungen
Kostenlos testen

Geld-zurück-Garantie, wenn du durch die Prüfung fällst

Review generated flashcards

Leg kostenfrei los
Du hast dein AI Limit auf der Website erreicht

Erstelle unlimitiert Karteikarten auf StudySmarter

Inhaltsverzeichnis
Inhaltsverzeichnis
  • Geprüfter Inhalt
  • Letzte Aktualisierung: 14.02.2024
  • 13 Minuten Lesezeit
  • Inhalte erstellt durch
    Lily Hulatt Avatar
  • Content überprüft von
    Gabriel Freitas Avatar
  • Inhaltsqualität geprüft von
    Gabriel Freitas Avatar
Melde dich kostenlos an, um Karteikarten zu speichern, zu bearbeiten und selbst zu erstellen.
Erklärung speichern Erklärung speichern

Springe zu einem wichtigen Kapitel

    Einführung in die C++ STL

    Die C++ Standard Template Library (STL) ist ein leistungsstarkes Feature von C++, das den Entwicklern hilft, ihren Code effizient und effektiv zu schreiben. Sie ist eine Sammlung von fertigen, generischen Klassen und Funktionen, die eine breite Palette von alltäglichen Programmieraufgaben erleichtern.

    Beispielsweise bietet C++ STL Algorithmen zur Sortierung von Daten innerhalb von Containern. Es würde sehr zeitaufwendig sein, diese Funktionen von Grund auf zu erstellen, aber mit STL sind sie sofort einsatzbereit und optimiert.

    Was ist die C++ STL?

    Die C++ STL ist eine Bibliothek eingebauter Klassen und Funktionen. Sie bietet vier Komponenten: Algorithmen, Container, Funktionen und Iteratoren. Algorithmen sind Prozeduren, die auf Datensätzen operieren. Container sind Objekte, die Daten speichern. Funktionen sind Objekte, die wie Funktionen agieren können. Iteratoren sind Objekte, die es ermöglichen, durch Container zu navigieren.

    In der Programmierung bezeichnet der Begriff "Container" ein Objekt, das dazu dient, andere Objekte zu speichern und zu organisieren. Container bieten Methoden, um die Größe zu ermitteln, Elemente hinzuzufügen, zu entfernen, zu finden und durch sie zu navigieren

    C++ STL einfach erklärt: Grundbegriffe und Konzepte

    Vereinfacht ausgedrückt, ist die C++ STL eine Bibliothek, die mit C++ ausgeliefert wird und eine Vielzahl nützlicher Datenstrukturen und Algorithmen bereitstellt, die Entwicklern dabei helfen, code effizient zu schreiben, indem sie Common-Task-Lösungen zur Verfügung stellt.

    Algorithmen Operieren auf Daten. Beispiele sind Suchen, Sortierungen und Modifizierungen.
    Container Speichern Daten. Es gibt verschiedene Arten von Containern wie Vektoren, Listen und Queues.

    Viele dieser Algorithmen und Datenstrukturen sind sehr komplex, aber die STL ermöglicht es den Entwicklern, sie zu nutzen, ohne sich um die Details kümmern zu müssen. Dies ermöglicht eine höhere Abstraktion und produktivere Codierung.

    Welche STL-Containers gibt es in C++?

    Es gibt verschiedene Arten von Containern in der C++ STL. Sie alle haben unterschiedliche Eigenschaften und werden für unterschiedliche Zwecke verwendet. Die Haupt-Containerarten sind:

    • Sequenzielle Container: array, vector, deque, forward_list, list
    • Containeradapter: stack, queue, priority_queue
    • Assoziative Container: set, multiset, map, multimap
    • Nicht sequenzielle Container: unordered_set, unordered_multiset, unordered_map, unordered_multimap

    Jeder Container hat seine eigene Verwendung und ist in bestimmten Situationen besser geeignet als andere.

    Definition C++ STL und wofür sie verwendet wird

    Die C++ Standard Template Library (STL) ist eine Softwarebibliothek, die ein Teil der C++ Standardbibliothek ist. Sie stellt vier Arten von C++ Templates zur Verfügung: Funktionen, Klassen, variadische Funktionen und variadische Klassen. Die STL erleichtert Entwicklern die Arbeit, indem sie effiziente, abstakte Datenstrukturen und Algorithmen bereitstellt, die auf einer Vielzahl von Daten arbeiten können.

    Die STL ist bekannt für ihre Effizienz und Flexibilität und ist weit verbreitet in der Anwendungsentwicklung, im Game-Programming, in systemnaher Programmierung und in vielen anderen Bereichen, in denen C++ zum Einsatz kommt.

    Die Datenstrukturen der C++ STL

    In der C++ STL gibt es eine Vielzahl von Datenstrukturen, die als Container bezeichnet werden und es ermöglichen, Daten auf verschiedene Arten zu speichern und zu organisieren. Diese Container umfassen sequenzielle Container wie array, vector und list sowie assoziative Container wie set, map und ihre Varianten. Zusätzlich gibt es auch Containeradapter wie queue und stack. Diese erweitern oder ändern das Verhalten von anderen Containern, um nützliche Datenstrukturen wie Queues und Stacks bereitzustellen.

    Verwendung von C++ STL Datenstrukturen

    Jeder dieser Container hat seine eigenen spezifischen Verwendungen und Stärken. Zum Beispiel, vectors und arrays sind extrem schnell beim Zugriff auf Elemente an zufälligen Positionen, während lists und forward_lists vorteilhaft sein können, wenn es wichtig ist, Elemente schnell an beliebigen Positionen hinzuzufügen oder zu löschen.

    Assoziative Container wie set, multiset, map und multimap speichern ihre Elemente nicht in einer bestimmten Reihenfolge. Stattdessen sind sie so organisiert, dass der Zugriff auf ihre Elemente extrem schnell ist, unabhängig von ihrer Position im Container.

    Um die bestmögliche Leistung zu erzielen, solltest du den richtigen Container für deine spezifische Aufgabe auswählen. Dies hängt von den spezifischen Anforderungen deines Programms ab, wie zum Beispiel der Häufigkeit bestimmter Operationen, der Menge der zu speichernden Daten und der Art der Arbeit, die du mit den Daten durchführen musst.

    Schauen wir uns ein Beispiel an: Wenn du eine große Menge von Elementen speichern musst und oft auf zufällige Elemente zugreifen musst, wäre ein vector oder ein deque eine gute Wahl. Wenn du jedoch oft Elemente in der Mitte des Containers einfügst oder löschst, könnte eine list oder forward_list besser geeignet sein.

    Beispiel C++ STL: Nutzung von Datenstrukturen

    Um die Verwendung von C++ STL-Datenstrukturen zu verdeutlichen, betrachten wir ein einfaches Beispiel für die Verwendung eines vectors. Im Folgenden ist ein kurzer C++-Codeausschnitt:

    #include 
    #include 
    
    int main() {
    std::vector numbers = {1, 2, 3, 4, 5};
    for(int number : numbers) {
    std::cout << number << ' ';
    }
    
    return 0;
    }
    

    Dieser Code erstellt einen vector von integers, füllt ihn mit einigen Zahlen und gibt diese dann aus. Wie du siehst, erledigt die STL all die harte Arbeit für uns. Es ist so einfach, einen Container zu erstellen und zu verwenden, und der erstellte Code ist klar und einfach zu verstehen.

    Was sind C++ Linked Lists STL?

    Die Linked List (verkettete Liste) ist eine Art sequenzieller Container in der C++ STL. Eine Linked List ist eine Datenstruktur, die aus einer Sequenz von Elementen besteht, die durch Links verbunden sind. Jedes Element enthält einen Wert und einen Link zum nächsten Element. Dadurch können Elemente effizient an einer beliebigen Position in der Liste eingefügt oder entfernt werden.

    In der STL wird die Linked List durch die list und die forward_list Klassen repräsentiert. Beide Klassen bieten effizientes Einfügen und Löschen von Elementen an jeder Position, aber sie ermöglichen keinen direkten Zugriff auf einzelne Elemente. Das Durchsuchen einer Linked List erfordert das Durchlaufen der Liste von Anfang an, bis das gesuchte Element gefunden wird.

    Es ist wichtig zu bedenken, dass die Wahl der richtigen Datenstruktur von den spezifischen Anforderungen deines Programms abhängt. Während Linked Lists in einigen Situationen nützlich sind, können sie in anderen Situationen ineffizient sein. Die Verwendung der richtigen Datenstruktur kann den Unterschied zwischen einem schnellen und einem langsamen Programm ausmachen.

    C++ STL Übung: Arbeiten mit Datenstrukturen

    Im Folgenden findest du ein Übungsbeispiel, das dir helfen wird, die Verwendung der C++ STL-Datenstrukturen zu verstehen. Die Aufgabe besteht darin, die Wörter in einem String zu zählen und die Anzahl der Vorkommen jedes Worts mit Hilfe einer map zu speichern.

    #include 
    #include 
    #include 
    #include 
    
    int main() {
    std::string str = "Das ist ein einfacher Test. Einmal mehr ist es ein Test.";
    std::map<:string int=""> wordCount;
    
    std::istringstream iss(str);
    std::string word;
    while (iss >> word) {
    ++wordCount[word];
    }
    
    for (const auto &pair : wordCount) {
    std::cout << pair.first << ": " << pair.second << '\n';
    }
    
    return 0;
    }
    

    Dieser Code erstellt eine map (oder assoziativen Container), die Strings auf Ganzzahlen abbildet. Er liest dann Wörter aus einem String ein und inkrementiert ihren Zähler in der map bei jedem Auftreten. Schließlich gibt er die Anzahl der Vorkommen jedes Worts aus.

    Komplexe Beispiele und Anwendungen der C++ STL

    Die C++ Standard Template Library (STL) ist eine leistungsstarke Bibliothek, die eine Vielzahl von Datenstrukturen und Algorithmen bietet. Durch zahlreiche praktische Anwendungsfälle und Übungen kannst du deine Fähigkeiten in C++ und der STL verbessern und optimieren. Sei es die Verarbeitung von Daten in Containerdatenstrukturen oder die Anwendung komplexer STL-Algorithmen, die STL ermöglicht es uns, effizienten und sauberen Code zu schreiben.

    C++ STL komplexe Beispiele: Praktische Anwendungsfälle

    Beginnen wir damit, ein komplexeres Problem zu lösen: Die Suche nach den k-Minsten Elementen in einem großen Datensatz.

    C++ STL bietet die Funktion nth_element, die genau diese Aufgabe erfüllt. Die Funktion nth_element ordnet die Elemente im gewünschten Bereich so an, dass sich das n-te Element an der Position befindet, wo es in einem sortierten Bereich wäre. Alle kleineren Elemente sind vor diesem Element und alle größeren oder gleichwertigen Elemente folgen darauf. Dies alles erfolgt in linearer Zeit. Hier ist ein Beispiel:

    #include 
    #include 
    #include 
    
    int main() {
    std::vector nums = {9, 1, 8, 2, 7, 3, 6, 4, 5};
    std::nth_element(nums.begin(), nums.begin() + 3, nums.end());
    
    for (int num : nums) {
    std::cout << num << " ";
    }
    
    return 0;
    }
    

    In diesem Beispiel finden wir die drei kleinsten Elemente in einem vector. Nach dem Aufruf von nth_element sind die ersten drei Elemente die kleinsten drei Elemente, allerdings nicht in sortierter Reihenfolge. Alle anderen Elemente sind größer als diese drei Elemente.

    nth_element ist ein sehr leistungsfähiges Werkzeug. Es ist ein in-place-Algorithmus, was bedeutet, dass kein zusätzlicher Speicher benötigt wird. Es ist auch sehr schnell, die Laufzeit beträgt im Durchschnitt \(O(n)\), was bedeutet, dass er die Arbeit in einer Zeit erledigt, die proportional zur Größe des Inputs ist.

    C++ STL Übung: Coding Herausforderungen

    Um deine Fähigkeiten in der Verwendung von STL zu verbessern, könnten Coding-Herausforderungen hilfreich sein. Sie ermöglichen es dir, verschiedene STL-Komponenten und ihre Anwendung in der Praxis zu verstehen. Nachfolgend findest du eine Übung, die mehrere STL-Komponenten verwendet.

    Die Aufgabe besteht darin, den zuerst eingetretenen einzigartigen Charakter in einem Stream zu finden. Du liest Zeichen aus einem Stream ein und musst das erste Zeichen finden, das nur einmal im Stream auftritt.

    #include 
    #include 
    #include 
    #include 
    
    void findFirstUnique(std::list& stream) {
    std::unordered_map::iterator> charMap;
    std::list uniqueChars;
    
    for(char& ch : stream) {
    if (charMap.find(ch) == charMap.end()) {
    uniqueChars.push_back(ch);
    charMap[ch] = --uniqueChars.end();
    } else {
    if (charMap[ch] != uniqueChars.end()) {
    uniqueChars.erase(charMap[ch]);
    charMap[ch] = uniqueChars.end();
    }
    }
    
    if (uniqueChars.empty())
    std::cout << "Kein einzigartiger Charakter gefunden \n";
    else
    std::cout << "Erster einzigartiger Charakter: " << uniqueChars.front() << '\n';
    }
    }
    
    int main() {
    std::list stream = {'a', 'b', 'c', 'a', 'b', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'e', 'd'};
    findFirstUnique(stream);
    
    return 0;
    }
    

    Dieses Beispiel verwendet mehrere C++ STL-Container, nämlich unordered_map und list. Der Algorithmus liest Zeichen aus einem Stream und speichert die Zeichen und ihre Positionen in der Liste der einzigartigen Zeichen. Wenn ein Zeichen mehr als einmal auftritt, wird es aus der Liste entfernt.

    Erweiterte Anwendung von C++ STL-Containers

    Außer der Verwendung grober STL-Container wie lists, vectors und maps gibt es auch fortgeschrittene Funktionen. Diese Funktionen sind insbesondere nützlich, wenn du versuchst, komplexe Probleme zu lösen und effizienten Code zu schreiben.

    Zum Beispiel, unordered_map ist eine mächtigere Version der map, die auf Hashing basiert. Im Gegensatz zu map, die eine sortierte Sammlung von Schlüssel-Wert-Paaren speichert und Operationen wie Insertion, Löschung und Suche in logarithmischer Zeit unterstützt, unterstützt unordered_map diese Operationen in konstanter Zeit, also unabhängig von der Größe der map. Das macht unordered_map in vielen Fällen zu einer besseren Option. Allerdings benötigt unordered_map mehr Speicher und die Elemente werden nicht sortiert gespeichert.

    Fehlerbehebung und Optimierung in C++ STL

    Beim Arbeiten mit der C++ STL können auch Fehler und Leistungsprobleme auftreten. Glücklicherweise bietet die STL viele Tools und Techniken, um diese Probleme zu beheben und die Funktionsweise deines Codes zu optimieren.

    Ein gängiges Problem bei der Verwendung von STL-Containern und -Algorithmen ist die ungültige Verwendung von Iteratoren. Jeder STL-Container stellt Iteratoren zur Verfügung, die verwendet werden, um durch die Elemente des Containers zu iterieren. Allerdings ist es wichtig, dies korrekt zu tun.

    Ein Iterator ist ein Objekt, das eine Schnittstelle bereitstellt, um auf Elemente in einem Container zuzugreifen. Es kann verwendet werden, um durch den Container zu iterieren, Elemente zu lesen oder zu modifizieren.

    Falscher Umgang mit Iteratoren, zum Beispiel das Entfernen eines Elements aus einem Container, während durch ihn iteriert wird, kann zu Fehlern führen. Um diesen Fehler zu vermeiden, ist es notwendig, den Iterator nach dem Löschen eines Elements zu aktualisieren. Mehrere STL-Container bieten Funktionen an, die ein Element entfernen und einen gültigen Iterator zurückgeben.

    std::vector nums = {1, 2, 3, 4, 5};
    for(auto it = nums.begin(); it != nums.end(); /* empty */) {
    if(*it % 2 == 0) {
    it = nums.erase(it);
    } else {
    ++it;
    }
    }
    

    In diesem Beispiel durchläuft der Code einen Vector und entfernt alle geraden Zahlen. Beachte, dass nums.erase(it) aufgerufen wird, um ein Element zu entfernen und dass der Rückgabewert dieses Aufrufs dem Iterator zugewiesen wird. Dadurch wird sichergestellt, dass der Iterator auch nach dem Löschen eines Elements gültig bleibt.

    Die C++ STL ist sehr flexibel und erlaubt viele Optimierungen. Indem du die richtigen STL-Container und -Algorithmen für deine spezifischen Anforderungen auswählst und sorgfältig auf das korrekte Handling von Iteratoren und anderen STL-Objekten achtest, kannst du sicherstellen, dass dein Code effektiv und effizient ist.

    C++ STL - Das Wichtigste

    • C++ STL: Eine Bibliothek, die eine Vielzahl von Datenstrukturen und Algorithmen bietet.
    • Algorithmen: Prozeduren, die auf Datensätzen operieren. Beispiele sind Suchen, Sortierungen und Modifikationen.
    • Container: Objekte, die Daten speichern, wie Vektoren, Listen und Queues.
    • Different Types of Containers: Sequenzielle, Containeradapter, Assoziative und Nicht sequenzielle Container.
    • Linked List in C++ STL: Eine Art sequenzieller Container, die aus einer Sequenz von Elementen besteht, die durch Links verbunden sind.
    • Verwendung von Funktion nth_element: Eine C++ STL Funktion zur Suche nach den k-Minsten Elementen in einem großen Datensatz.
    Lerne schneller mit den 12 Karteikarten zu C++ STL

    Melde dich kostenlos an, um Zugriff auf all unsere Karteikarten zu erhalten.

    C++ STL
    Häufig gestellte Fragen zum Thema C++ STL
    Was ist die C++ Standard Template Library (STL) und wozu wird sie verwendet?
    Die C++ Standard Template Library (STL) ist eine Sammlung von Template-Klassen und -Funktionen, die zur Bereitstellung von allgemeinen Programmierstrukturen wie Listen, Stapeln, Arrays, usw. dient. Sie wird verwendet, um den Entwicklungsprozess durch Wiederverwendung von Code zu beschleunigen und besseren Abstraktionsmechanismus bereitzustellen.
    Wie verwende ich verschiedene Containerklassen in der C++ STL?
    Die C++ Standard Template Library (STL) bietet verschiedene Containerklassen wie vector, list, set, map usw. Zum Verwenden erstellen Sie eine Instanz der Klasse, indem Sie den Containertyp deklarieren und Werte einfügen. Zum Beispiel `std::vector my_vector;` erzeugt einen leeren Vektor für Integer und `my_vector.push_back(1);` fügt die Zahl 1 hinzu.
    Welche Algorithmen sind in der C++ STL verfügbar und wie wende ich sie an?
    Die C++ Standard Template Library (STL) bietet eine große Anzahl an Algorithmen, darunter Sortieralgorithmen (sort, partial_sort), Suchalgorithmen (binary_search, find), Permutationsalgorithmen (next_permutation), Zahlungsalgorithmen (count, accumulate) und andere. Diese Algorithmen können auf Datenstrukturen wie Vektoren, Listen usw. angewendet werden, indem die Anfangs- und End-Iterator dieser Strukturen als Parameter übergeben werden.
    Wie kann ich eigene Funktionen oder Objekte mit der C++ STL verwenden?
    Eigene Funktionen oder Objekte können mit der C++ Standard Template Library (STL) verwendet werden, indem sie als Argumente an STL-Funktionen oder -Algorithmen übergeben werden. Des Weiteren können eigene Objekte in STL-Containern wie std::vector oder std::list gespeichert und verwaltet werden.
    Wie kann ich die C++ STL für Multithreading und parallele Programmierung nutzen?
    Die C++ Standardbibliothek (STL) bietet keine direkte Unterstützung für Multithreading oder parallele Programmierung. Allerdings gibt es Bibliotheken wie die C++11 Thread-Bibliothek und OpenMP, die für diesen Zweck verwendet werden können.
    Erklärung speichern

    Teste dein Wissen mit Multiple-Choice-Karteikarten

    Welche Art von Datenstrukturen bietet die C++ STL an?

    Was ist der Zweck der C++ Standard Template Library (STL)?

    Was sind die Unterschiede zwischen einer unordered_map und einer map in C++ STL?

    Weiter
    Wie stellen wir sicher, dass unser Content korrekt und vertrauenswürdig ist?

    Bei StudySmarter haben wir eine Lernplattform geschaffen, die Millionen von Studierende unterstützt. Lerne die Menschen kennen, die hart daran arbeiten, Fakten basierten Content zu liefern und sicherzustellen, dass er überprüft wird.

    Content-Erstellungsprozess:
    Lily Hulatt Avatar

    Lily Hulatt

    Digital Content Specialist

    Lily Hulatt ist Digital Content Specialist mit über drei Jahren Erfahrung in Content-Strategie und Curriculum-Design. Sie hat 2022 ihren Doktortitel in Englischer Literatur an der Durham University erhalten, dort auch im Fachbereich Englische Studien unterrichtet und an verschiedenen Veröffentlichungen mitgewirkt. Lily ist Expertin für Englische Literatur, Englische Sprache, Geschichte und Philosophie.

    Lerne Lily kennen
    Inhaltliche Qualität geprüft von:
    Gabriel Freitas Avatar

    Gabriel Freitas

    AI Engineer

    Gabriel Freitas ist AI Engineer mit solider Erfahrung in Softwareentwicklung, maschinellen Lernalgorithmen und generativer KI, einschließlich Anwendungen großer Sprachmodelle (LLMs). Er hat Elektrotechnik an der Universität von São Paulo studiert und macht aktuell seinen MSc in Computertechnik an der Universität von Campinas mit Schwerpunkt auf maschinellem Lernen. Gabriel hat einen starken Hintergrund in Software-Engineering und hat an Projekten zu Computer Vision, Embedded AI und LLM-Anwendungen gearbeitet.

    Lerne Gabriel kennen

    Entdecke Lernmaterialien mit der kostenlosen StudySmarter App

    Kostenlos anmelden
    1
    Über StudySmarter

    StudySmarter ist ein weltweit anerkanntes Bildungstechnologie-Unternehmen, das eine ganzheitliche Lernplattform für Schüler und Studenten aller Altersstufen und Bildungsniveaus bietet. Unsere Plattform unterstützt das Lernen in einer breiten Palette von Fächern, einschließlich MINT, Sozialwissenschaften und Sprachen, und hilft den Schülern auch, weltweit verschiedene Tests und Prüfungen wie GCSE, A Level, SAT, ACT, Abitur und mehr erfolgreich zu meistern. Wir bieten eine umfangreiche Bibliothek von Lernmaterialien, einschließlich interaktiver Karteikarten, umfassender Lehrbuchlösungen und detaillierter Erklärungen. Die fortschrittliche Technologie und Werkzeuge, die wir zur Verfügung stellen, helfen Schülern, ihre eigenen Lernmaterialien zu erstellen. Die Inhalte von StudySmarter sind nicht nur von Experten geprüft, sondern werden auch regelmäßig aktualisiert, um Genauigkeit und Relevanz zu gewährleisten.

    Erfahre mehr
    StudySmarter Redaktionsteam

    Team Informatik Lehrer

    • 13 Minuten Lesezeit
    • Geprüft vom StudySmarter Redaktionsteam
    Erklärung speichern Erklärung speichern

    Lerne jederzeit. Lerne überall. Auf allen Geräten.

    Kostenfrei loslegen

    Melde dich an für Notizen & Bearbeitung. 100% for free.

    Schließ dich über 22 Millionen Schülern und Studierenden an und lerne mit unserer StudySmarter App!

    Die erste Lern-App, die wirklich alles bietet, was du brauchst, um deine Prüfungen an einem Ort zu meistern.

    • Karteikarten & Quizze
    • KI-Lernassistent
    • Lernplaner
    • Probeklausuren
    • Intelligente Notizen
    Schließ dich über 22 Millionen Schülern und Studierenden an und lerne mit unserer StudySmarter App!
    Mit E-Mail registrieren