假设我们有一个单链表,我们必须检查找到第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