LeetCode 分类刷题:203. 移除链表元素

题目

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点

解析

作者:灵茶山艾府

链接:https://leetcode.cn/problems/remove-linked-list-elements/solutions/2806456/tao-lu-ru-he-you-ya-di-shan-chu-lian-bia-ah8z/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

答案

javascript 复制代码
var removeElements = function(head, val) {
    const dummy = new ListNode(0, head);
    let cur = dummy;
    while (cur.next) {
        if (cur.next.val === val) {
            cur.next = cur.next.next; // 删除下一个节点
        } else {
            cur = cur.next; // 继续向后遍历链表
        }
    }
    return dummy.next;
};

// 作者:灵茶山艾府
// 链接:https://leetcode.cn/problems/remove-linked-list-elements/solutions/2806456/tao-lu-ru-he-you-ya-di-shan-chu-lian-bia-ah8z/
// 来源:力扣(LeetCode)
// 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

复杂度分析

时间复杂度:O(n),其中 n 是链表的长度。

空间复杂度:O(1)。

相关推荐
进击的小头6 分钟前
一阶IIR低通滤波器:从原理到嵌入式实战
c语言·算法
2301_8112329819 分钟前
C++中的契约编程
开发语言·c++·算法
2401_8290040219 分钟前
C++中的访问者模式
开发语言·c++·算法
青槿吖27 分钟前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
sin_hielo27 分钟前
leetcode 1984
数据结构·算法·leetcode
古城小栈44 分钟前
开发常用 宏
算法·rust
m0_7482486544 分钟前
C语言向C++过渡
c语言·c++·算法
qq_423233901 小时前
跨语言调用C++接口
开发语言·c++·算法