Computer >> Máy Tính >  >> Lập trình >> Python

Chương trình Python để tìm độ dài của danh sách được liên kết mà không sử dụng đệ quy

Khi cần tìm độ dài của danh sách được liên kết mà không sử dụng đệ quy, một phương pháp để thêm các phần tử vào danh sách được liên kết và một phương pháp để tính độ dài của danh sách được liên kết được xác định.

Dưới đây là một minh chứng cho điều tương tự -

Ví dụ

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

class my_linked_list:
   def __init__(self):
      self.head = None
      self.last_node = None

   def add_value(self, my_data):
      if self.last_node is None:
         self.head = Node(my_data)
         self.last_node = self.head
      else:
         self.last_node.next = Node(my_data)
         self.last_node = self.last_node.next

   def calculate_length(self):
      curr = self.head
      length_val = 0
      while curr:
         length_val = length_val + 1
         curr = curr.next
      return length_val

my_instance = my_linked_list()
my_data = input('Enter elements of the linked list ').split()
for elem in my_data:
   my_instance.add_value(int(elem))
print('The length of the linked list is ' + str(my_instance.calculate_length()))

Đầu ra

Enter elements of the linked list 34 12 56 86 32 99 0 6
The length of the linked list is 8

Giải thích

  • Lớp 'Node' được tạo.

  • Một lớp ‘my_linked_list’ khác với các thuộc tính bắt buộc được tạo.

  • Nó có chức năng ‘init’ được sử dụng để khởi tạo phần tử đầu tiên, tức là ‘head’ thành ‘None’ và nút cuối cùng thành ‘None’.

  • Một phương thức khác có tên là ‘add_value’ được xác định, được sử dụng để thêm dữ liệu vào danh sách được liên kết.

  • Một phương thức khác có tên là ‘allow_length’ được định nghĩa dùng để tìm độ dài của danh sách được liên kết.

  • Một đối tượng của lớp ‘my_linked_list’ được tạo.

  • Đầu vào của người dùng được thực hiện để lấy các phần tử trong danh sách được liên kết.

  • Các phương thức được gọi trên nó để thêm dữ liệu.

  • Phương thức allow_length được gọi để tìm độ dài của danh sách.

  • Đầu ra này được hiển thị trên bảng điều khiển.