Sobes.tech
Back to questions
Junior — Middle
67

Можете ли вы объяснить, что такое связанный список и как его реализовать на Python?

Answer from AI

sobes.tech AI

Связанный список — это структура данных, состоящая из узлов, где каждый узел содержит данные и ссылку на следующий узел в списке. В отличие от массивов, связанные списки не требуют непрерывного блока памяти и позволяют эффективно вставлять и удалять элементы.

Пример реализации односвязного списка на Python:

class Node:
    def __init__(self, data):
        self.data = data
        self.next = None

class LinkedList:
    def __init__(self):
        self.head = None

    def append(self, data):
        new_node = Node(data)
        if not self.head:
            self.head = new_node
            return
        last = self.head
        while last.next:
            last = last.next
        last.next = new_node

    def print_list(self):
        current = self.head
        while current:
            print(current.data, end=' -> ')
            current = current.next
        print('None')

# Использование
ll = LinkedList()
ll.append(1)
ll.append(2)
ll.append(3)
ll.print_list()  # Вывод: 1 -> 2 -> 3 -> None