mafulechka
mafulechka23. Mai 2019 02:49

Baumdatenstruktur

Eine Verknüpfte Liste ist eine Kette von Knoten, die über "Nächste" -Zeiger verbunden sind. Ein Baum ähnelt einer verknüpften Liste, aber jeder Knoten kann mit mehreren Knoten verknüpft werden.

Wenn wir von einem Baum sprechen, meinen wir grundsätzlich einen binären Baum, also eine Struktur, die zwei Kinder hat, links und rechts.


Binäre Baumdarstellung

Ein binärer Baumknoten wird durch eine Struktur dargestellt, die ein Datenelement und zwei Zeiger auf andere Strukturen des gleichen Typs enthält.

struct node
{
  int data;
  struct node *left;
  struct node *right;
};

Ein spezieller Zeiger namens ROOT zeigt auf den Knoten, der der Elternknoten aller anderen Knoten ist.

Außerdem zeigen Knoten, die keine Kinder haben, mit ihrem linken und rechten Zeiger auf NULL .

Ein einfacher Binärbaum mit drei Knoten kann wie folgt erstellt werden:

/* Initialize nodes */
struct node *root;
struct node *one = NULL;
struct node *two = NULL;
struct node *three = NULL;

/* Allocate memory */
one = malloc(sizeof(struct node));
two = malloc(sizeof(struct node));
three = malloc(sizeof(struct node));

/* Assign data values */
one->data = 1;
two->data = 2;
three->data = 3;

/* Connect nodes */
one->left = two;
one->right = three;
two->left = NULL;
two->right = NULL;
three->left = NULL;
three->right = NULL;

/* Save address of first node in root */
root = one;

In wenigen Schritten haben wir einen Binärbaum mit drei Knoten erstellt.

Bäume können viel tiefer und komplexer sein. Die in jedem Knoten gespeicherten Daten können komplexer sein und viel mehr Kinder als nur zwei haben.

Bäume auftragen

Bäume und ihre Varianten sind eine äußerst nützliche Datenstruktur mit vielen praktischen Anwendungen.

  • Binäre Suchbäume (BST) werden verwendet, um schnell zu überprüfen, ob sich ein Element in einer Menge befindet.
  • Heap (Set) ist eine Art Baum, der verwendet wird, um mehrere Elemente zu sortieren.
  • Eine modifizierte Version des Baums namens Tries wird in modernen Routern verwendet, um Routing-Informationen zu speichern.
  • Die beliebtesten Datenbanken verwenden B-Bäume (B-Bäume) und T-Bäume (T-Bäume), die Varianten der Baumstruktur sind, die wir oben gelernt haben, um ihre Daten zu speichern.
  • Compiler verwenden einen Syntaxbaum, um die Syntax jedes von Ihnen geschriebenen Programms zu überprüfen (validieren).

Vollständiges C-Programm zur Implementierung von Tree

#include <stdio.h>
#include <stdlib.h>

struct node {
    int data;
    struct node* left;
    struct node* right;
};

struct node* createNode(value){
    struct node* newNode = malloc(sizeof(struct node));
    newNode->data = value;
    newNode->left = NULL;
    newNode->right = NULL;

    return newNode;
}

struct node* insertLeft(struct node *root, int value) {
    root->left = createNode(value);
    return root->left;
} 


struct node* insertRight(struct node *root, int value){
    root->right = createNode(value);
    return root->right;
}

int main(){
    struct node *root = createNode(1);
    insertLeft(root, 2);
    insertRight(root, 3);

    printf("The elements of tree are %d %d %d", root->data, root->left->data, root->right->data);
}

Programmausgabe

1 2 3

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken