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
相关推荐
JHC0000001 小时前
基于Ollama,Milvus构建的建议知识检索系统
人工智能·python·milvus
mOok ONSC1 小时前
SpringBoot项目中读取resource目录下的文件(六种方法)
spring boot·python·pycharm
py有趣2 小时前
力扣热门100题之环形链表
算法·leetcode·链表
GIS兵墩墩2 小时前
postgis--PostgreSQL16及其plpython3u扩展
python·postgis
new Object ~2 小时前
LangChain的短期记忆存储实现
python·langchain
魔都吴所谓2 小时前
【Python】从零构建:IP地理位置查询实战指南
开发语言·python·tcp/ip
py有趣2 小时前
力扣热门100题之回文链表
算法·leetcode·链表
测试19982 小时前
使用Python自动化生成接口测试用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
Kk.08022 小时前
数据结构|链表 刷题
数据结构·链表
智算菩萨3 小时前
【Pygame】第10章 游戏状态管理与场景切换机制
python·游戏·pygame