美文网首页
19. 删除链表的倒数第N个节点

19. 删除链表的倒数第N个节点

作者: 周英杰Anita | 来源:发表于2020-06-23 21:45 被阅读0次

    给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。

    示例:

    给定一个链表: 1->2->3->4->5, 和 n = 2.
    

    当删除了倒数第二个节点后,链表变为 1->2->3->5.
    说明:

    给定的 n 保证是有效的。
    

    进阶:

    你能尝试使用一趟扫描实现吗?
    

    思路--快慢指针

    创建一个哑节点slowNode和fastNode  ,将其指向head
    先让fastNode 先走n步
    接着让fastNode 和slowNode同时走,当fastNode 走到链表的尾部时,slowNode.next就是倒数第n个节点
    删除倒数第n个节点:slowNode.next = slowNode.next.next
    这里要特殊处理一下链表长度为1的情况
    

    python3解法

    # Definition for singly-linked list.
    # class ListNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.next = None
    
    class Solution:
        def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:
            if not head: return head
            slowNode = ListNode(None)
            slowNode.next = head
            fastNode = slowNode
            step = 0
            while step < n:
                fastNode = fastNode.next
                step += 1
            while fastNode.next != None:
                fastNode = fastNode.next
                slowNode = slowNode.next
            if slowNode.next == head:
                head = head.next
            else:
                slowNode.next = slowNode.next.next
            return head
    

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    相关文章

      网友评论

          本文标题:19. 删除链表的倒数第N个节点

          本文链接:https://www.haomeiwen.com/subject/ndskfktx.html