转码刷 LeetCode 笔记[2]:203. 移除链表元素(python)

题目

第一次错解

移除链表节点,一般用的方法是,把前驱节点的指针域指向目标节点的下一个节点。先创建虚拟头节点,指向头节点,然后通过循环找到等于 val 的节点。

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        dummy = ListNode(0)  # 虚拟头节点
        dummy.next = head  # 此时,链表head从dummy开始
        current = dummy  # 还是应该写成 current = dummy?
        # for current in head:
        while(current.next):
            if current.next.val == val:
                current.next = current.next.next
            current = current.next
        return head

错哪了?

  1. 返回值错了

如果链表开头的节点就等于 val ,那在循环中,这个旧的 head 节点就不在链表里了,所以不能返回这个被废弃的 head 节点。而应该改成 dummy.next,它表示此时真正的头节点。

  1. 删除结点之后,current 无需右移

因为 current.next = current.next.next 已经删除了一个节点,如果再次右移,就会在循环中漏掉一个节点。

第二次修正

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        dummy = ListNode(0)  # 虚拟头节点
        dummy.next = head  # 此时,链表head从dummy开始
        current = dummy  # 还是应该写成 current = head?
        # for current in head:
        while(current.next):
            if current.next.val == val:
                current.next = current.next.next
            else:
                current = current.next
        return dummy.next

现在是正确的了!

相关推荐
mo_alo5 分钟前
Everything Claude Code 完全指南:给 Claude Code 装上涡轮增压【安装和使用超详细教程!!!】
笔记·embedding·ai编程·claude·ecc
kyq___16 分钟前
环路稳定性补偿学习笔记
笔记·学习
CyrusCJA34 分钟前
日语零基础每天学习笔记【11-20】
笔记·学习
oi..1 小时前
Flag入门—Flag在返回包中
网络·笔记·测试工具·安全·网络安全
职豚求职小程序1 小时前
[特殊字符]京东笔试在线系统练习笔试题库更新版本
笔记
NULL指向我1 小时前
信号处理学习笔记2:软件RC二阶高通\低通滤波
笔记·学习·信号处理
左左右右左右摇晃1 小时前
ConcurrentHashMap ——put + get
java·开发语言·笔记
朱一头zcy1 小时前
设计模式入门:最简单的模板方法模式
笔记·设计模式·模板方法模式
alphaTao1 小时前
LeetCode 每日一题 2026/3/23-2026/3/29
服务器·windows·leetcode
qq_389600132 小时前
pads 学习笔记
笔记·学习