小阳同学刷题日记-203. 移除链表元素

2024-04-11 16:52

本文主要是介绍小阳同学刷题日记-203. 移除链表元素,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

        思路: 

        两种思路:① 不创建虚拟节点的思路;② 创建虚拟节点的思路

① 不创建虚拟节点的思路

  1. 首先处理头节点,如果头节点的值等于 val,则将头节点后移直到其值不等于 val
  2. 然后遍历链表,删除所有值为 val 的节点。
  3. 需要维护一个指针 prev 指向当前节点的前一个节点,以便在删除节点时重新连接链表。
  4. 删除节点的方法是将 prev 节点的 next 指针指向当前节点的下一个节点,并释放当前节点的内存空间。
  5. 如果当前节点的值不等于 val,则将 prev 指针移动到当前节点,继续遍历下一个节点。
  6. 遍历结束后,返回头节点作为新的头节点

 ② 创建虚拟节点的思路

  1. 创建一个虚拟头节点 dummyHead,使其 next 指向原链表的头节点 head
  2. 使用指针 cur 遍历链表,初始时指向虚拟头节点 dummyHead
  3. 在遍历过程中,如果当前节点的下一个节点的值等于 val,则删除该节点。
  4. 删除节点的方法是将当前节点的 next 指针指向下下个节点,并释放被删除节点的内存空间。
  5. 如果当前节点的下一个节点的值不等于 val,则将 cur 指针移动到下一个节点。
  6. 遍历结束后,返回虚拟头节点 dummyHead 的下一个节点作为新的头节点。

         代码:

① 不创建虚拟节点的代码 

class Solution {
public:ListNode* removeElements(ListNode* head, int val) {// 删除头节点while(head != NULL && head->val == val){ // 当头节点的值等于给定值时循环删除ListNode* temp = head; // 临时指针指向头节点head = head->next; // 移动头指针到下一个节点delete temp; // 释放被删除的头节点}// 删除非头节点ListNode* cur = head; // 使用cur指针遍历链表,初始指向头节点while(cur != NULL && cur->next != NULL){ // 循环直到cur指针指向链表尾节点的下一个节点或cur指针为空if(cur->next->val == val){ // 如果当前节点的下一个节点的值等于给定值ListNode* temp = cur->next; // 临时指针指向当前节点的下一个节点cur->next = cur->next->next; // 将当前节点的下一个节点指针指向下下个节点delete temp; // 释放被删除的节点}else{ // 如果当前节点的下一个节点的值不等于给定值cur = cur->next; // 移动当前节点指针到下一个节点}}return head; // 返回处理后的链表头节点指针}
};

 ② 创建虚拟节点的代码

class Solution {
public:ListNode* removeElements(ListNode* head, int val) {ListNode* dummyHead = new ListNode(0); // 创建虚拟头节点,值为0dummyHead->next = head; // 将虚拟头节点指向原链表的头节点ListNode* cur = dummyHead; // 使用cur指针遍历链表,初始指向虚拟头节点while(cur->next != NULL){ // 循环直到cur指针指向链表尾节点的下一个节点或cur指针为空if(cur->next->val == val){ // 如果当前节点的下一个节点的值等于给定值ListNode* temp = cur->next; // 临时指针指向当前节点的下一个节点cur->next = cur->next->next; // 将当前节点的下一个节点指针指向下下个节点delete temp; // 释放被删除的节点}else{ // 如果当前节点的下一个节点的值不等于给定值cur = cur->next; // 移动当前节点指针到下一个节点}            }return dummyHead->next; // 返回处理后的链表头节点指针,即虚拟头节点的下一个节点}
};

两种方法各有优缺点,我们来分析一下:

方法一:使用虚拟头节点

优点:

  1. 简化了对头节点的处理:由于引入了虚拟头节点,不需要特殊处理头节点,统一了对节点的处理逻辑。
  2. 避免了对空链表的特殊情况处理:即使链表为空,也可以直接操作虚拟头节点,无需额外的判断和处理。

缺点:

  1. 需要额外的空间:引入了虚拟头节点,会占用额外的内存空间。
  2. 删除节点时需要注意细节:删除节点时,需要特别注意处理头节点的情况,以及确保链表的连接性。

方法二:不使用虚拟头节点

优点:

  1. 不需要额外的空间:不引入虚拟头节点,节省了额外的内存空间。
  2. 逻辑较为清晰:对头节点的处理和其他节点的处理分开,逻辑相对清晰。

缺点:

  1. 需要特殊处理头节点:由于没有虚拟头节点,需要单独处理头节点的情况,会增加代码的复杂度。
  2. 需要处理空链表的特殊情况:在链表为空时,需要额外的判断和处理。

        综上所述,两种方法各有优缺点,具体选择哪种方法取决于实际情况和个人偏好。如果对空间复杂度要求较高,且能够确保代码逻辑正确性,可以选择不使用虚拟头节点的方法;如果追求代码的简洁和清晰,且能够接受额外的空间消耗,可以选择使用虚拟头节点的方法。

 

努力学习,天天向上!

这篇关于小阳同学刷题日记-203. 移除链表元素的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/894647

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque