前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Leetcode][python]Remove Nth Node From End of List

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

作者头像
蛮三刀酱
发布2019-03-26 16:45:36
3550
发布2019-03-26 16:45:36
举报

题目大意

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

解题思路

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

代码

代码语言:javascript
复制
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

总结

本文参与?腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017年08月24日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体同步曝光计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目大意
  • 解题思路
  • 代码
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com