Найдите частоту чисел, используя linkedlist

#python #python-3.x #linked-list

#python #python-3.x #связанный список

Вопрос:

Найдите частоту чисел, используя linkedlist.

Получение ошибки SIGTSTP — превышение временного предела при выполнении приведенного ниже кода. Кто-нибудь может мне помочь, где я ошибаюсь?

 class Element(object):
    def __init__(self,value):
        self.value = value
        self.next = None

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

    def append(self, new):
        current = self.head
        if self.head:
            while current.next:
                current = current.next
            current.next = new
        else:
            self.head = new

    def traverse(self):
        current = self.head
        while current != None:
            print(current.value)
            current = current.next            

arr = list(map(int, input().split()))

ll = LinkedList()
for i in arr:
    e = Element(i)
    ll.append(e)

ll.traverse()

def frequency(a):
    current = a.head
    while current != None:
        count = 1
        while current.next != None:
            if current.value == current.next.value:
                current =1
                if current.next.next != None:
                    current.next = current.next.next
                else:
                    current.next = None
        print(str(current.value) " : "   str(count))
        current = current.next

frequency(ll)        
  

Комментарии:

1. Почему вы увеличиваете значение вашего элемента в вашем связанном списке?

2. @FarhoodET я добавляю объект element в linkedlist

Ответ №1:

Все выглядит нормально, кроме частоты. Вам нужно будет сохранить две ссылки, одну на текущий элемент, а другая будет проходить по остальной части списка, начиная с current. Это дает вам что-то, на что можно опереться?

Также обратите внимание, что ваша текущая реализация изменит базовый связанный список, хотя вы действительно можете выполнять «пропуск» с указателями, чтобы предотвратить перечисление одного и того же элемента несколько раз, имо предпочтительнее избегать изменения базовой структуры таким образом.