Heim >Backend-Entwicklung >Python-Tutorial >Wie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? (Codebeispiel)

Wie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? (Codebeispiel)

青灯夜游
青灯夜游Original
2019-03-18 11:56:287965Durchsuche

Wie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? Der folgende Artikel wird Ihnen helfen zu verstehen, was eine einfach verknüpfte Liste ist und wie Sie einige sehr grundlegende Operationen an einer einfach verknüpften Liste ausführen, wie z. B. Einfügen und Ausgabe. Ich hoffe, dass er für Sie hilfreich ist.

Wie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? (Codebeispiel)

Was ist eine einfach verknüpfte Liste?

Bevor wir einfach verknüpfte Listen verstehen, müssen wir zunächst verstehen, was ein Knoten ist.

Knoten ist der Baustein der verknüpften Liste, der aus zwei Teilen besteht:

1. Datenteil: enthält früher Daten

2 zeigen Sie auf den nächsten Zeiger auf die Knotenposition.

In einer einfach verknüpften Liste enthält der Adressteil jedes Knotens Informationen über den Standort des nächsten Knotens. Dies bildet eine Reihe von Ketten oder Links. Der erste Knoten der verknüpften Liste wird vom Kopfzeiger verfolgt; der letzte Knoten zeigt auf None.

Sehen wir uns das folgende Diagramm an, um dies besser zu verstehen:

Wie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? (Codebeispiel)

Hinweis: Im obigen Diagramm zeigt das letzte Element 1 auf None. Auch wenn diese Knoten zusammenhängend zueinander gezeichnet sind, können sie sich tatsächlich an zusammenhängenden Speicherorten befinden oder auch nicht.

Wie füge ich Knoten in eine einfach verknüpfte Liste ein und gebe sie aus?

1. Erstellen Sie eine einfach verknüpfte Liste

Zuerst müssen Sie einen Knoten erstellen, um eine einfach verknüpfte Liste zu erstellen. Dazu erstellen wir eine Node-Klasse mit den Eigenschaften data und nextNode. Wie bereits erwähnt, enthält das Datenattribut die Daten und nextNode zeigt einfach auf den nächsten Knoten in der verknüpften Liste. Wir legen den Standardwert für nextNode auf None fest. Dazu können Sie Getter- und Setter-Methoden verwenden.

Da nun die Node-Klasse erstellt wurde, ist es an der Zeit, die LinkedList-Klasse zu erstellen. Dies hat nur ein Attribut, Kopf. Standardmäßig zeigt dies auf „Keine“. Wenn der Header auf „None“ zeigt, bedeutet dies, dass die verknüpfte Liste leer ist. Um die Anzahl der Knoten in der verknüpften Liste zu verfolgen, können wir der LinkedList-Klasse ein Größenattribut hinzufügen und es standardmäßig auf 0 setzen.

2. Knoten einfügen

Dies ist die Methode der LinkedList-Klasse. Wir können an einer beliebigen Stelle in der verknüpften Liste einen neuen Knoten einfügen. Um die Codierung jedoch einfach und effizient zu halten, fügen wir neue Knoten immer am Anfang der verknüpften Liste hinzu. Mit anderen Worten: Der Kopf zeigt immer auf den zuletzt hinzugefügten Knoten .

Wenn wir am Ende der Liste einen neuen Knoten hinzufügen, müssen wir zusätzliche Arbeit leisten, um das Ende der Liste zu finden und ihn dann hinzuzufügen. Dies ist ein verschwenderischer Vorgang. Dies kann jedoch erreicht werden, wenn Sie einen anderen Zeiger beibehalten, nennen wir ihn Endzeiger, der auf den letzten Knoten zeigt.

Im Folgenden stellen wir die erstere Methode vor, also das Einfügen eines Knotens am Anfang der verknüpften Liste.

Angenommen, wir müssen 7 zur verknüpften Liste hinzufügen, müssen wir die folgenden Schritte ausführen:

● Erstellen Sie ein Knotenobjekt, wobei 7 Daten darstellt und die nächsten Knotenpunkte auf den Kopfknoten

● Zeigen Sie den Kopfzeiger auf diesen neuen Knoten

Erhöhen Sie schließlich das Größenattribut um 1 und geben Sie True zurück, wenn das Einfügen erfolgreich ist , der Benutzer weiß, was passiert ist.

3. Ausgabeknoten

Dies ist die Methode der LinkedList-Klasse. Um die Daten in allen Knoten in der verknüpften Liste zu drucken, müssen wir jeweils einen Knoten durchlaufen und den Datenteil jedes Knotens drucken.

Implementierungscode:

class Node:
   def __init__(self,data,nextNode=None):
       self.data = data
       self.nextNode = nextNode
   def getData(self):
       return self.data
   def setData(self,val):
       self.data = val
   def getNextNode(self):
       return self.nextNode
   def setNextNode(self,val):
       self.nextNode = val
class LinkedList:
   def __init__(self,head = None):
       self.head = head
       self.size = 0
   def getSize(self):
       return self.size
   def addNode(self,data):
       newNode = Node(data,self.head)
       self.head = newNode
       self.size+=1
       return True
       
   def printNode(self):
       curr = self.head
       while curr:
           print(curr.data)
           curr = curr.getNextNode()
myList = LinkedList()
print("Inserting")
print(myList.addNode(5))
print(myList.addNode(15))
print(myList.addNode(25))
print("Printing")
myList.printNode()
print("Size")
print(myList.getSize())

Was sind die Vor- und Nachteile einfach verknüpfter Listen?

Vorteile:

● Es handelt sich um eine dynamische Datenstruktur, in der das Einfügen und Löschen einfach ist, weil wir es nicht brauchen um das Element zu verschieben. Es genügt, den nächsten Zeiger zu aktualisieren.

●Stapel- und Warteschlangendatenstrukturen können mithilfe verknüpfter Listen einfach implementiert werden.

Nachteile

●Der nächste Zeiger beansprucht zusätzlichen Speicher.

●Kann nicht zufällig aufgerufen werden. Die verknüpfte Liste muss von Anfang an durchlaufen werden, um einen bestimmten Knoten zu erreichen.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere spannende Inhalte finden Sie in den entsprechenden Tutorial-Kolumnen auf der chinesischen PHP-Website! ! !

Das obige ist der detaillierte Inhalt vonWie füge ich Knoten in eine einfach verknüpfte Python-Liste ein und gebe sie aus? (Codebeispiel). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn