在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