remove nth node from end of list

25 年 6 月 29 日 星期日
230 字
2 分钟

problem

my solution:

python
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeNthFromEnd(self, head: Optional[ListNode], n: int) -> Optional[ListNode]:
        pir = head
        while n and pir:
            pir = pir.next
            n -= 1
        if n > 0:
            return head
        dummy = ListNode(next=head)
        pre = dummy
        cur = head
        while pir:
            pre = pre.next
            cur = cur.next
            pir = pir.next
        pre.next = cur.next
        return dummy.next

Note that: return the dummy.next due to the header could be deleted.

Logics can be modified:

python
class Solution:
    def removeNthFromEnd(self, head: Optional[ListNode], n: int) -> Optional[ListNode]:
        # 由于可能会删除链表头部,用哨兵节点简化代码
        left = right = dummy = ListNode(next=head)
        for _ in range(n):
            right = right.next  # 右指针先向右走 n 步
        while right.next:
            left = left.next
            right = right.next  # 左右指针一起走
        left.next = left.next.next  # 左指针的下一个节点就是倒数第 n 个节点
        return dummy.next

作者:灵茶山艾府
链接:https://leetcode.cn/problems/remove-nth-node-from-end-of-list/solutions/2004057/ru-he-shan-chu-jie-dian-liu-fen-zhong-ga-xpfs/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

文章标题:remove nth node from end of list

文章作者:Sirui Chen

文章链接:https://blog.siruichen.me/posts/19remove_nth_node_from_end_of_list[复制]

最后修改时间:


商业转载请联系站长获得授权,非商业转载请注明本文出处及文章链接,您可以自由地在任何媒体以任何形式复制和分发作品,也可以修改和创作,但是分发衍生作品时必须采用相同的许可协议。
本文采用CC BY-NC-SA 4.0进行许可。