LeetCode203 移除链表元素

前言

题目: 203.移除链表元素
文档: 代码随想录------移除链表元素
编程语言: C++
解题状态: 解答错误,忘了链表的遍历是如何进行的了

思路

对于链表的操作,最好可以给一个虚拟表头方便操作。另外需要注意的是,在删除链表的节点后,我们需要手动进行清理内存。

代码

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* removeElements(ListNode* head, int val) {
        ListNode* dummyHead = new ListNode(0); // 设置一个虚拟头结点
        dummyHead -> next = head; // 将虚拟头结点指向head,这样方便后面做删除操作
        ListNode* cur = dummyHead;
        while (cur -> next != NULL) {
            if(cur -> nex t-> val == val) {
                ListNode* tmp = cur -> next;
                cur -> next = cur -> next -> next;
                delete tmp;
            } else {
                cur = cur -> next;
            }
        }
        head = dummyHead -> next;
        delete dummyHead;
        return head;
    }
};
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1)
相关推荐
yyjtx6 分钟前
DHU上机打卡D29
数据结构·c++·算法
Doro再努力6 分钟前
【Linux操作系统16】Linux进程管理深度解析:从fork到内核链表设计
linux·运维·链表
feng_you_ying_li10 分钟前
类和对象(中)
c++
元亓亓亓13 分钟前
考研408--数据结构--day16--内部排序(下)
数据结构·408·内部排序
_Twink1e14 分钟前
[算法竞赛]四、树
数据结构·笔记·算法
Max_uuc16 分钟前
【架构心法】炸毁巨石阵:从单体巨兽到微内核 (Microkernel) 插件化架构的 Qt C++ 工业软件演进
c++·qt·架构
「QT(C++)开发工程师」18 分钟前
# [特殊字符] Day 1:Qt 信号槽原理深入 - 核心学习笔记
c++·qt
无限进步_2 小时前
面试题 02.04. 分割链表 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
Mr YiRan6 小时前
C++面向对象继承与操作符重载
开发语言·c++·算法
蚊子码农11 小时前
算法题解记录--239滑动窗口最大值
数据结构·算法