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
相关推荐
Csvn8 小时前
🌟 LangChain 30 天保姆级教程 · Day 13|OutputParser 进阶!让 AI 输出自动转为结构化对象,并支持自动重试!
python·langchain
‎ദ്ദിᵔ.˛.ᵔ₎9 小时前
LIST 的相关知识
数据结构·list
cch89189 小时前
Python主流框架全解析
开发语言·python
M--Y9 小时前
Redis常用数据类型
数据结构·数据库·redis
sg_knight9 小时前
设计模式实战:状态模式(State)
python·ui·设计模式·状态模式·state
好运的阿财9 小时前
process 工具与子agent管理机制详解
网络·人工智能·python·程序人生·ai编程
张張4089 小时前
(域格)环境搭建和编译
c语言·开发语言·python·ai
weixin_423533999 小时前
【Windows11离线安装anaconda、python、vscode】
开发语言·vscode·python
༾冬瓜大侠༿10 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz10 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展