在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

以上是 在Python中找到链表的最后K个节点的程序 的全部内容, 来源链接: utcz.com/z/322425.html

回到顶部