wordpress

Reverse the Linked List in Python: Code to Revert a Linked List

Introduction

Una lista enlazada es una estructura de datos que consta de nodos, donde cada nodo contiene un valor y una referencia al siguiente nodo en la lista. En una lista enlazada, los nodos están conectados de forma secuencial, lo que permite un acceso rápido a los elementos y una fácil inserción y eliminación de elementos.

En este artículo, exploraremos cómo revertir una lista enlazada en Python. Revertir una lista enlazada significa cambiar el orden de los nodos de la lista, de manera que el último nodo se convierta en el primero y el primer nodo se convierta en el último.

Creating a Linked List

Antes de poder revertir una lista enlazada, primero debemos crear una lista enlazada en Python. Para ello, necesitamos definir una clase Node que represente un nodo en la lista enlazada. Cada nodo debe tener un valor y una referencia al siguiente nodo en la lista.

A continuación, creamos una clase LinkedList que representa la lista enlazada en sí. La clase LinkedList tiene un atributo head que apunta al primer nodo de la lista. También tiene métodos para agregar elementos a la lista y para imprimir la lista enlazada.

Aquí está el código para crear una lista enlazada en Python:

«`python
class Node:
def __init__(self, value):
self.value = value
self.next = None

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

def add_element(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
else:
current = self.head
while current.next:
current = current.next
current.next = new_node

def print_list(self):
current = self.head
while current:
print(current.value)
current = current.next
«`

Recomendado:  Converting HTML to PDF files using Python: Recommended libraries

Con este código, podemos crear una lista enlazada y agregar elementos a ella. Por ejemplo:

«`python
linked_list = LinkedList()
linked_list.add_element(1)
linked_list.add_element(2)
linked_list.add_element(3)
linked_list.print_list()
«`

Esto imprimirá:

«`
1
2
3
«`

Reversing a Linked List

Una vez que tenemos una lista enlazada, podemos proceder a revertirla. Para revertir una lista enlazada, necesitamos cambiar las referencias de los nodos de manera que el último nodo se convierta en el primero y el primer nodo se convierta en el último.

Para hacer esto, necesitamos recorrer la lista enlazada y cambiar las referencias de los nodos. Comenzamos con tres punteros: uno que apunta al nodo actual, otro que apunta al nodo anterior y otro que apunta al nodo siguiente.

En cada iteración, actualizamos las referencias de los nodos de la siguiente manera:

  • El puntero al nodo siguiente se actualiza para que apunte al nodo anterior.
  • El puntero al nodo anterior se actualiza para que apunte al nodo actual.
  • El puntero al nodo actual se actualiza para que apunte al nodo siguiente.

Este proceso se repite hasta que llegamos al final de la lista enlazada, es decir, hasta que el puntero al nodo actual sea None.

Code Implementation

Aquí está el código para revertir una lista enlazada en Python:

«`python
def reverse_linked_list(linked_list):
current = linked_list.head
previous = None

while current:
next_node = current.next
current.next = previous
previous = current
current = next_node

linked_list.head = previous
«`

Este código toma una instancia de la clase LinkedList como argumento y revierte la lista enlazada representada por esa instancia.

Para probar este código, podemos crear una lista enlazada y luego revertirla:

«`python
linked_list = LinkedList()
linked_list.add_element(1)
linked_list.add_element(2)
linked_list.add_element(3)

Recomendado:  Python 2D array: Cómo crear un arreglo bidimensional en Python

print(«Original Linked List:»)
linked_list.print_list()

reverse_linked_list(linked_list)

print(«Reversed Linked List:»)
linked_list.print_list()
«`

Esto imprimirá:

«`
Original Linked List:
1
2
3
Reversed Linked List:
3
2
1
«`

Testing the Reversed Linked List

Para asegurarnos de que la lista enlazada se haya revertido correctamente, podemos realizar algunas pruebas adicionales. Podemos crear una lista enlazada con diferentes elementos y luego revertirla para verificar si los elementos están en el orden correcto.

También podemos probar la función reverse_linked_list con una lista enlazada vacía para asegurarnos de que maneje correctamente ese caso.

«`python
linked_list = LinkedList()
linked_list.add_element(4)
linked_list.add_element(5)
linked_list.add_element(6)

print(«Original Linked List:»)
linked_list.print_list()

reverse_linked_list(linked_list)

print(«Reversed Linked List:»)
linked_list.print_list()
«`

Esto imprimirá:

«`
Original Linked List:
4
5
6
Reversed Linked List:
6
5
4
«`

Como podemos ver, la lista enlazada se revierte correctamente y los elementos están en el orden inverso.

Conclusion

Revertir una lista enlazada en Python es un proceso relativamente sencillo. Utilizando punteros y cambiando las referencias de los nodos, podemos cambiar el orden de los nodos de la lista enlazada.

En este artículo, hemos explorado cómo crear una lista enlazada en Python, cómo revertir una lista enlazada y cómo probar la lista enlazada revertida. Espero que este artículo te haya dado una comprensión clara de cómo revertir una lista enlazada en Python y cómo implementar el código para hacerlo.

Si tienes alguna pregunta o comentario, no dudes en dejarlos a continuación.

Autor

osceda@hotmail.com

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *