一个 Python 程序用于找出单链表中第 K 个倒数节点


假设我们有一个单链表,我们需要检查找出第 K 个倒数节点(0 为起始索引)的值。我们必须单次遍历解决这个问题。

所以,如果输入如下 node = [5,4,6,3,4,7], k = 2,那么输出将是 3,因为第二个倒数(索引 3)节点的值为 3。

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

  • klast := node

  • last := node

  • for i 从 0 到 k,操作

    • last := last 的 next

  • while last 的 next 不为空,操作

    • last := last 的 next

    • klast := klast 的 next

  • return 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

更新于: 09-Oct-2020

1K+ 浏览

开启你的 职业生涯

完成课程获得认证

开始学习
广告