Binärer Baum in c
In c, a Binärbaum ist eine Instanz einer Baumdatenstruktur mit einem übergeordneten Knoten, der möglicherweise eine maximale Anzahl von zwei untergeordneten Knoten besitzt; 0, 1 oder 2 Nachkommenknoten. Jeder einzelne Knoten in a Binärbaum hat einen eigenen Wert und zwei Zeiger auf seine Kinder, einen Zeiger für das linke Kind und das andere für das rechte Kind.
Binärbaumerklärung
A Binärbaum kann in C unter Verwendung eines Objekts namens deklariert werden Struktur Das zeigt einen der Knoten im Baum.
StrukturknotenOben ist eine Erklärung von einem Binärbaum Knotenname als Knoten. Es enthält drei Werte; Einer ist die Datenspeichervariable und die anderen beiden sind die Zeiger für das Kind. (Links und rechtes Kind des übergeordneten Knotens).
Fakten des binären Baumes
Auch für große Datensätze mit a Binärbaum erleichtert und schneller die Suche. Die Anzahl der Bäste ist nicht begrenzt. Im Gegensatz zu einem Array können Bäume jeglicher Art hergestellt und erhöht werden, basierend auf dem, was von einer Person verlangt wird.
Implementierung von Binärbäumen in C
Das Folgende ist eine Schritt-für-Schritt-Anleitung zur Implementierung a Binärbaum in c.
Schritt 1: Deklarieren Sie einen binären Suchbaum
Erstellen Sie einen Struct -Knoten mit drei Arten von Daten, wie z.
StrukturknotenSchritt 2: Erstellen Sie neue Knoten im binären Suchbaum
Erstellen Sie einen neuen Knoten, indem Sie eine Funktion erstellen, die eine Ganzzahl als Argument akzeptiert und den Zeiger auf den mit diesem Wert erstellten neuen Knoten liefert. Verwenden Sie die malloc () -Funktion in c für die dynamische Speicherzuweisung für den erstellten Knoten. Initialisieren Sie das linke und rechte Kind in Null und geben Sie den Knotenname zurück.
Struct Node* create (Datentypdaten)Schritt 3: Einlegen Sie die rechte und linke Kind in Binärbaum
Erstellen von Funktionen Insert_Left und Insert_Right, die zwei Eingänge akzeptieren, die der Wert sind, der eingefügt wird, und der Zeiger auf den Knoten, an den beide Kinder verbunden sind. Rufen Sie die Funktion erstellen, um einen neuen Knoten zu erstellen, und weisen Sie den zurückgegebenen Zeiger dem linken Zeiger des linken Kindes oder dem rechten Zeiger des rechten Kindes des Stammerteils zu.
struct node* insert_left (struct node* root, Datentypdaten)Schritt 4: Zeigen Sie Knoten des binären Baums mithilfe von Traversalmethoden an
Wir können Bäume mit drei Methoden des Traversals in C anzeigen. Diese Traversalmethoden sind:
1: Vorbestellung durchträgt
In dieser Traversal -Methode gehen wir die Knoten in eine Richtung von durch parent_node-> links_child-> right_child.
void Pre_order (Knoten * root)2: Nachbestellung durch den Bestellung
In dieser Traversal -Methode werden wir die Knoten in eine Richtung von der durchlaufen links_child-> right_child-> parent_node->.
void display_post_order (knoten * root)3: In-Ordnung-Traversal
In dieser Traversal -Methode gehen wir die Knoten in eine Richtung von durch links_node-> root_child-> right_child.
void display_in_order (knoten * root)Schritt 5: Löschung im binären Baum durchführen
Wir können das Erstellen löschen Binärbaum Durch das Löschen der Kinder mit der übergeordneten Knotenfunktion in C wie folgt wie folgt.
void Delete_t (Knoten * root)C Programm des binären Suchbaums
Das Folgende ist die vollständige Implementierung des binären Suchbaums in der C -Programmierung:
#enthaltenIm obigen Code deklarieren wir zuerst a Knoten Verwendung Struktur. Dann initialisieren wir einen neuen Knoten als “Node1Und den Speicher dynamisch verwenden malloc () in C mit Daten und zwei Zeiger Typ Kinder mit dem deklarierten Knoten angeben. Danach zeigen wir den Knoten vorbei printf () Funktion und nennen Sie es in der hauptsächlich() Funktion. Dann ist die Insertion_node () Die Funktion wird erstellt, wobei, wenn Knotendaten null sind, dann null ist Node1 ist im Ruhestand, sonst werden Daten in die platziert Knoten(Elternteil) des linken und rechten Kindes. Das Programm beginnt die Ausführung von der hauptsächlich() Funktion, die einen Knoten erzeugt, der einige Beispielknoten als Kinder verwendet und dann in Ordnung mit durchqueren.
Ausgang
Abschluss
Bäume werden häufig verwendet, um Daten in nichtlinearer Form zu halten. Binärbäume sind Arten von Bäumen, bei denen jeder Knoten (Elternteil) zwei Nachkommen im linken Kind und das rechte Kind hat. A Binärbaum ist eine vielseitige Methode zum Übertragen und Speichern von Daten. Es ist effizienter im Vergleich zur Verbindungsliste in C. Im obigen Artikel haben wir das Konzept von a gesehen Binärbaum mit der Schritt-für-Schritt-Implementierung von a Binärer Suchbaum in c.