Lila25mila
Lila25mila5. April 2019 04:26

Verlinkte Liste

In diesem Tutorial lernen Sie die verknüpfte Liste und ihre Anwendungen kennen. Außerdem erfahren Sie, wie Sie verschiedene Verknüpfungslistenoperationen erstellen und ausführen.


Beim Schatzsuche-Spiel beginnen Sie damit, nach dem ersten Hinweis zu suchen. Wenn Sie ihn finden, finden Sie anstelle des Schatzes den Ort des nächsten Hinweises und dann des nächsten und so weiter. Du folgst den Hinweisen, bis du den Schatz erreichst.

Die verknüpfte Liste ähnelt dem Spielbeispiel. Es ist eine Reihe verbundener "Knoten", die die "Adresse" des nächsten Knotens enthalten. Jeder Knoten kann einen Datenpunkt speichern, der eine Zahl, eine Zeichenfolge oder ein beliebiger anderer Datentyp sein kann.

Repräsentieren einer verknüpften Liste

Wir müssen irgendwo anfangen, also geben wir der Adresse des ersten Knotens einen speziellen Namen namens HEAD. Außerdem kann der letzte Knoten in der verknüpften Liste identifiziert werden, weil sein nächster Teil auf NULL zeigt.

Wie wird auf einen anderen Knoten verwiesen?

Lassen Sie uns darüber nachdenken, was jeder Knoten enthält:

  • Datenelement;
  • Adresse eines anderen Hosts.

Wir verketten das Datenelement und den Link zum nächsten Knoten zu einer Struktur wie:

struct node
{
  int data;
  struct node *next;
};

Das Verständnis der Struktur des verknüpften Listenknotens ist der Schlüssel zum Verständnis.

Jeder Strukturknoten hat ein Datenelement und einen Zeiger auf einen anderen Strukturknoten. Lassen Sie uns eine einfache verknüpfte Liste mit drei Elementen erstellen, um zu sehen, wie sie funktioniert.

/* Инициализируем узлы */
struct node *head;
struct node *one = NULL;
struct node *two = NULL;
struct node *three = NULL;

/* Выделяем память */
one = malloc(sizeof(struct node));
two = malloc(sizeof(struct node));
three = malloc(sizeof(struct node));

/* Назначаем значения данных */
one->data = 1;
two->data = 2;
three->data=3;

/* Соединяем узлы */
one->next = two;
two->next = three;
three->next = NULL;

/* Сохраняем адрес первого узла в голове */
head = one;

Wenn Sie keine der obigen Zeilen verstehen, brauchen Sie nur die Zeiger und Strukturen zu aktualisieren.

In nur wenigen Schritten haben wir eine einfache verkettete Liste mit drei Knoten erstellt.

Der Vorteil einer verknüpften Liste liegt in der Möglichkeit, eine Kette zu unterbrechen und wieder daran anzuhängen. Wenn Sie beispielsweise Element 4 zwischen 1 und 2 platzieren möchten, gehen Sie folgendermaßen vor:

  • Erstellen Sie einen neuen Strukturknoten und weisen Sie ihm Speicher zu.
    *Addieren Sie seinen Datenwert als 4
  • Zeigen Sie mit dem nächsten Zeiger auf einen Strukturknoten, der 2 als Datenwert enthält
  • Ändern Sie den nächsten Zeiger "1" auf den gerade erstellten Knoten.

Um etwas Ähnliches in einem Array zu tun, müssten die Positionen aller nachfolgenden Elemente verschoben werden.

Hilfsprogramm für verknüpfte Listen

Listen sind eine der beliebtesten und effizientesten Datenstrukturen, die in allen Programmiersprachen wie C, C++, Python, Java und C# implementiert sind.

Außerdem sind verknüpfte Listen eine großartige Möglichkeit, um zu lernen, wie Zeiger funktionieren. Indem Sie verknüpfte Listen üben, können Sie sich darauf vorbereiten, komplexere Datenstrukturen wie Diagramme und Bäume zu lernen.

Рекомендуємо хостинг 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