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

现在是正确的了!

相关推荐
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [arm][lds]
linux·运维·arm开发·笔记·学习
无名咸鱼6 小时前
CICD部署流程详解文档笔记
笔记·ci/cd
秋风战士6 小时前
通信算法之306:精通FPGA-笔记核心
笔记·fpga开发
一颗正在价投韭菜6 小时前
《范仲淹传》读书笔记与摘要
笔记·学习·范仲淹
teeeeeeemo8 小时前
js 实现 ajax 并发请求
开发语言·前端·javascript·笔记·ajax
老虎06278 小时前
JavaWeb(苍穹外卖)--学习笔记17(Apache Echarts)
笔记·学习·apache
快去睡觉~11 小时前
力扣109:有序链表转换二叉搜索树
算法·leetcode·链表
I'm a winner11 小时前
FPGA+护理:跨学科发展的探索(二)
笔记·fpga开发
柳鲲鹏12 小时前
bitbake –s:列出所有可编译的模块
笔记