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

题目描述:

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

输入输出实例:

思路:这道题目我们可以用双指针来做,让first和second指针之间的距离为n+1,然后我们first和second指针都往后移动,这样当first所指的为最后一个节点的后一个(即空节点)的时候,我们的second刚好在倒数第n个节点的前一个节点,然后我们second.next = second.next.next,这样达到去除第n个节点的目的。根据上述思路我们有以下代码:

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]:
        #创建一个虚拟节点方便处理边界
        dummy = ListNode()
        dummy.next = head
        first = dummy
        second = dummy

        for _ in range(n+1):
            first = first.next
        
        while first:
            first = first.next
            second = second.next

        second.next = second.next.next

        return dummy.next
相关推荐
曾阿伦14 分钟前
Python项目管理从Poetry迁移到uv:极速体验与实操指南
开发语言·python·uv
2301_8187305617 分钟前
turtle学习
python
AnalogElectronic26 分钟前
windows文件加解密工具,python实现,速度极快,篡改文件头尾信息以及还原
开发语言·windows·python
m0_5281744532 分钟前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
AMoon丶41 分钟前
Golang--锁
linux·开发语言·数据结构·后端·算法·golang·mutex
漏刻有时1 小时前
宝塔面板实现按年月自动备份目录至阿里云 OSS(python脚本、大文件分片上传版)
python·阿里云·云计算
用户0332126663671 小时前
使用 Python 查找并替换 PDF 中的文本
python
2201_756206341 小时前
1111111
开发语言·python
李日灐1 小时前
改造红黑树实现封装 map/set:感受C++ 标准容器的精妙设计与底层实现
开发语言·数据结构·c++·后端·算法·红黑树
李日灐1 小时前
【优选算法1】双指针经典算法题
数据结构·c++·后端·算法·刷题·双指针