[Leetcode][python]Remove Nth Node From End of List

题目大意

删除链表中倒数第n个节点

解题思路

加一个虚假头结点dummy,并使用双指针p1和p2。p1先向前移动n个节点(从dummy节点开始移动,所以移动了n其实是移动到了前一位),然后p1和p2同时移动,当p1.next==None时,此时p2.next指的就是需要删除的节点前面一个节点,将其指向.next.next即可

代码

class Solution(object):
    def removeNthFromEnd(self, head, n):
        """ :type head: ListNode :type n: int :rtype: ListNode """
        dummy = ListNode(0)
        dummy.next = head
        p1 = p2 = dummy
        while n: 
            p1=p1.next
            n -= 1
        while p1.next:  # p1后指针指向空后跳出
            p1 = p1.next
            p2 = p2.next
        p2.next = p2.next.next
        return dummy.next

总结

全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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