转码刷 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

现在是正确的了!

相关推荐
下午见。几秒前
C语言结构体入门:定义、访问与传参全解析
c语言·笔记·学习
im_AMBER3 分钟前
React 16
前端·笔记·学习·react.js·前端框架
lkbhua莱克瓦2421 分钟前
Java基础——常用算法5
java·开发语言·笔记·github
摇滚侠1 小时前
Spring Boot3零基础教程,响应式编程的模型,笔记109
java·spring boot·笔记
YuanDaima20482 小时前
[CrewAI] 第5课|基于多智能体构建一个 AI 客服支持系统
人工智能·笔记·多智能体·智能体·crewai
许长安3 小时前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
蒙奇D索大3 小时前
【11408学习记录】考研英语长难句精析:三步拆解真题复杂结构,轻松攻克阅读难关!
笔记·学习·考研·改行学it
蒙奇D索大4 小时前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
小安同学iter5 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50
_dindong5 小时前
笔试强训:Week-4
数据结构·c++·笔记·学习·算法·哈希算法·散列表