题解 | #快慢指针# #链表中倒数最后k个结点#

链表中倒数最后k个结点

https://www.nowcoder.com/practice/886370fe658f41b498d40fb34ae76ff9

#coding:utf-8
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param pHead ListNode类 
# @param k int整型 
# @return ListNode类
#
class Solution:
    def FindKthToTail(self , pHead , k ):
        # write code here

        #init
        fast = pHead
        slow = pHead

        #process
        ##corner case
        if pHead == None:
            return None
        size = 0
        dummy = pHead
        while dummy != None:
            size += 1
            dummy = dummy.next
        #print ("Size is: ", size)
        if size < k:
            return None

        ##common case
        for i in range(0, k):
            fast = fast.next
        while fast != None:
            fast = fast.next 
            slow = slow.next 
            #print ("Slow val: ")

        return slow

全部评论

相关推荐

07-29 14:09
门头沟学院 Java
我爱o泡我爱o泡o泡果奶ooo
26加瓦鼠鼠:三个offer了,停手吧,回头是岸
点赞 评论 收藏
分享
06-25 16:25
梧州学院 Java
愿汐_:项目介绍那么长,然而你做了啥就一句话?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务