在Python中找到链表的最后K个节点的程序

假设我们有一个单链表,我们必须检查找到第k个最后一个节点(索引为0)的值。我们必须通过一次解决。

因此,如果输入类似于node = [5,4,6,3,4,7],k = 2,则输出将为3,因为倒数第二个(索引3)节点的值为3。

为了解决这个问题,我们将遵循以下步骤-

  • klast:=节点

  • 最后:=节点

  • 对于0到k范围内的i,执行

    • 最后:=最后一个

  • 当倒数第二个不为空时,执行

    • 最后:=最后一个

    • klast:= klast的下一个

  • Klast的返回值

让我们看下面的实现以更好地理解-

示例

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

def make_list(elements):
   head = ListNode(elements[0])
   for element in elements[1:]:
      ptr = head
      while ptr.next:
         ptr = ptr.next
      ptr.next = ListNode(element)

   return head

class Solution:
   def solve(self, node, k):
      klast = node
      last = node
      for i in range(k):
         last = last.next
      while last.next:
         last = last.next
         klast = klast.next
      return klast.val

ob = Solution()l1 = make_list([5,4,6,3,4,7])
print(ob.solve(l1, 2))

输入项

[5,4,6,3,4,7], 2

输出结果

3
猜你喜欢