在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
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短