一个 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
广告