【快乐手撕LeetCode题解系列】——移除链表元素

news2025/1/13 20:01:34

【【快乐手撕LeetCode题解系列】——移除链表元素😎

  • 前言🙌
    • 删除有序数组中的重复项🙌
    • 解法一:
      • 画图分析:😍
      • 思路分析:😍
      • 源代码分享:😍
    • 解法二:
      • 画图分析:😍
      • 思路分析:😍
      • 源代码分享:😍
    • 解法三:
      • 画图分析:😍
      • 思路分析:😍
      • 源代码分享:😍
  • 总结撒花💞

追梦之旅,你我同行

   
😎博客昵称:博客小梦
😊最喜欢的座右铭:全神贯注的上吧!!!
😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主!

😘博主小留言:哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘
在这里插入图片描述

前言🙌

    哈喽各位友友们😊,我今天又学到了很多有趣的知识现在迫不及待的想和大家分享一下!😘我仅已此文,和大家分享【快乐手撕LeetCode题解系列】——移除链表元素~ 都是精华内容,可不要错过哟!!!😍😍😍

删除有序数组中的重复项🙌

题目内容

在这里插入图片描述

解法一:

画图分析:😍

在这里插入图片描述
在这里插入图片描述

思路分析:😍

  • 首先先认真读题,分析出解题的思路
  • 这里要定义一个prev指针,这个是关键。保存cur前一个结点的位置。
  • 如果cur指向的值不为val,就让prev保留这个位置,再让cur指向下一个位置
  • 让cur指向的值为val,就要进行删除。一般的情况下就是将prev-> next = cur - > next,然后将cur指向的结点释放掉,最后再将cur 指向prev->next;
  • 当cur = NULL时,遍历完这个单链表了。循环结束,将head返回即可。

源代码分享:😍

struct ListNode* removeElements(struct ListNode* head, int val)
{
    struct ListNode* prev = NULL;
    struct ListNode* cur = head;
    while(cur)
    {
        //删除
        if(cur->val  == val)
        {
            if(cur == head)
            {
                head = cur->next;
                free(cur);
                cur = head;
            }
            else
            {
                prev->next = cur->next;
                free(cur);
                cur = prev->next;
            }
            
        }
        else
        {
            prev = cur;
            cur = cur->next;
        }
    }
    return head;
}

解法二:

画图分析:😍

在这里插入图片描述

思路分析:😍

  • 这里是利用插入的思想来解决这道题目
  • 插入的时候也要注意一点,一般的情况都是进行尾插的,但是要注意只有一个节点的时候是进行头插操作的。
  • 当cur指向的值不为val就让插入到新的链表中。让tail->next = cur ; tail->next = cur。这是一般的情况,如果是头插的话就得让head = tail = cur。
  • 如果当cur指向的值为val,就得定义一个指针del保留cur的位置,然后将cur指向下一个。把del指向的空间删除即可
  • 注意野指针和空指针的问题。当最后一个元素是val,将其free掉后,tail->next就是个野指针了。需要将其置为NULL。当链表的值都为val,将链表全部删除后,head就是个野指针了。需要将其置为NULL。

源代码分享:😍

struct ListNode* removeElements(struct ListNode* head, int val)
{
    struct ListNode*cur = head;
    struct ListNode*tail = NULL;
    head = NULL;
    while(cur)
    {
        if(cur->val != val)
        {
            //头插
            if(tail == NULL)
            {
               head = tail = cur;
            }
            //尾插
            else
            {
                tail->next = cur;
                tail = tail->next;
            }
            cur = cur->next;
            
        }
        else
        {
             struct ListNode*del = cur;
             cur = cur->next;
             free(del);
        }
    }

    if(tail != NULL && tail->next != NULL)
    tail->next = NULL;
    return head;
}

解法三:

画图分析:😍

在这里插入图片描述

思路分析:😍

  • 这里先建立一个带头结点的空链表。这是对第二种解法的一种简化。比较方便插入,这里就无需将头插分开讨论了,都是尾插。
  • 其他的思路都和第二种解法相似就不过多赘述。
  • 需要注意的是,如果末尾的数据为val,当删除最后一个结点后。需要将tail->next置为空。
  • 返回的不是head,而是head->next。因为head是不带值的头,其后面那个才是有效的结点。

源代码分享:😍

struct ListNode* removeElements(struct ListNode* head, int val)
{
   struct ListNode* tail = NULL;
   struct ListNode* cur = head;
   //带哨兵位的头结点
   head = tail = (struct ListNode*)malloc(sizeof(struct ListNode));
   while(cur)
   {
       if(cur->val == val)
       {
           struct ListNode*del = cur;
           cur = cur->next;
           free(del);
       }
       else
       {
           tail->next = cur;
           tail = tail->next;
           cur = cur->next;
       }
   }
   if(tail != NULL && tail->next != NULL)
   {
       tail->next = NULL;
   }
   return head->next;
}

程序输出结果验证: 😊
在这里插入图片描述

总结撒花💞

   本篇文章旨在分享【【快乐手撕LeetCode题解系列】——移除链表元素。希望大家通过阅读此文有所收获!😘如果我写的有什么不好之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/419575.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vite打包后直接使用浏览器打开,显示空白问题

vite打包后,直接用浏览器打开显示空白 1.需求: 安卓webview等浏览器直接打开文件显示 2.原因 (1)资源路径错误: vite.config.js 配置 base: “./” (在webpack中则配置publicPath: "./"即可…

Windows ActiveMQ安装

Windows ActiveMQ 安装 ActiveMQ下载:ActiveMQ Java JDK下载:Java JDK20 下载完成之后解压ZIP安装包,解压后得到如下文件夹 找到根目录下/bin/win64/activemq.bat 双击打开,如果提示权限记得使用管理员身份 。 如提示Unable to e…

学习数据结构第5天(线性表的链式表示)

线性表的链式表示单链表的定义单链表的基本操作双链表双链表的基本操作循环链表块状链表存储结构顺序表和链表的比较线性表的顺序存储结构的特点是逻辑关系上相邻的两个数据元素在物理位置上也是相邻的。我们会发现虽然顺序表的查询很快,时间复杂度为O(1)O(1)O(1),但…

Java EE企业级应用开发(SSM)第5章

第5章Spring MVC入门一.预习笔记 1.Spring MVC是所有使用OOP编程语言都应该遵守的规范 2.Spring MVC的特点 强大的灵活性、非侵入性和可配置性 提供了一个前端控制器DispatcherServlet,开发者无须额外开发控制器对象 分工明确,每一个功能由一个专门…

日前、日内两阶段需求响应热电综合能源联合调度研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

深度学习之卷积神经网络0基础入门学习教程——浅层深度学习(全网最详细,不详细你打我)(看不懂你打我)(对小白没用你打我)

作为一个双非学校的人工智能硕士研究生,我在深度学习入门之初,学校里没人带,只能靠自己一点一点的摸索,走了很多弯路,因为自己并不懂得从哪里入手,从吴恩达的课到李沐的课等等无数种课,无数种书…

Microsoft project 2013安装教程(含激活方法)

目录 一、介绍 二、安装教程 三、激活 一、介绍 Microsoft project 2013中文版是由微软推出的一款项目管理软件,软件将可用性、功能和灵活性等完美地融合在一起,可以有效提升办公人员的效率,利用project 2013用户可以制作出…

SecureCRT8.5的下载、安装和注册(详细图解)

SecureCRT8.5的下载、安装和注册请先关闭杀毒软件和防火墙。 关闭防火墙 先打开电脑的设置,在弹出的界面里找到并点击更新和安全。 找到并点击Windows 安全中心,再在右侧找到并点击防火墙和网络保护选项。 将域网络、专用网络、公用网络这三个选项设…

数据结构入门-11-红黑树

史上最负盛名的平衡二叉树–红黑树,但其实就是2-3树的一种实现 文章目录一、红黑树性质二、红黑树性质推导过程2-3树2.3.1 如何维护绝对平衡2-3树2.3.2 红黑树&2-3树2.3.3 再来看红黑树的性质1.每个节点为 Black or Red2.根节点是Black3.每一个叶子节点(最后的空…

2023年郑州重点建设项目名单公布,中创“算力数据中心”项目入选!

4月7日,郑州市人民政府网站公布2023年郑州市重点建设项目名单,名单共列项目680个,总投资1.08万亿元,年度计划投资2691亿元。 在创新驱动能力提升项目名单里,中创算力与人民网人民数据(国家大数据灾备中心&a…

小程序实现消息订阅及发送

在我们的家政服务小程序中,用户可以新增预约。一般的场景是新增预约的时候提醒用户接收通知,在状态变更的时候我们来发送订阅消息。本篇我们来讲解一下小程序订阅消息功能的开发。 1 开通订阅消息模板 要想发送订阅消息,首先需要选用一个消…

【ES】数据同步集群

【ES】数据同步&集群3.数据同步3.1.思路分析3.1.1.同步调用3.1.2.异步通知3.1.3.监听binlog3.1.4.选择3.2.实现数据同步3.2.1.思路3.2.2.导入demo3.2.3.声明交换机、队列1)引入依赖2)声明队列交换机名称3)声明队列交换机3.2.4.发送MQ消息…

解决macOS IntelliJ IDEA 卡顿问题

写在前面的话1:我在撰写这篇博客时候,所用的IntelliJ IDEA版本是IntelliJ IDEA 2022.3.3 (Ultimate Edition),你需要知道可能对于不同的IntelliJ IDEA版本会有一定的差异 写在前面的话2:如果我这篇博客可以帮助到你,请…

国内可用的 ChatGPT

国内可用的 ChatGPT 替代列表功能和使用顺便推荐列表 https://chatgpt.qdymys.cn/ :三小时只能用10次 https://alllinkai.com/ :体验完,要登录,不推荐 https://gpttalk.live/ :每天限制使用次数 https://chatgpt-c…

深入探讨机器学习中的过拟合现象及其解决方法

1. What❓ 过拟合(Overfitting)是指在机器学习中,模型在训练集上表现较好,但在测试集或实际应用中表现较差的现象。过拟合发生时,模型过于复杂地学习了训练集中的噪声、异常值或特定模式,从而导致对新样本…

限流:计数器、漏桶、令牌桶 三大算法的原理与实战(史上最全)

限流 限流是面试中的常见的面试题(尤其是大厂面试、高P面试) 注:本文以 PDF 持续更新,最新尼恩 架构笔记、面试题 的PDF文件,请到文末《技术自由圈》公号获取 为什么要限流 简单来说: 限流在很多场景中用来…

教程 | 近红外数据的预处理和平均(上)

前言 近红外光谱(NIRS)是一种测量流经传感器所在组织的血液中氧合水平的方法。它基于这样一个事实,即含氧血红蛋白和脱氧血红蛋白具有不同的吸收光谱,因此你会看到它有不同的颜色。大多数近红外系统在每个光源光电二极管发射2个波长的光,通常…

【记录】ORB_SLAM2 例程(README文件里的单双目RDB-D、ROS、AR、外接摄像头、点云)

第一次跑 ORB_SLAM2,记录一下一、普通环境0.build.sh 遇到的问题(1)usleep(2)AlignedBit1.单目、TUM数据集2.双目、KITTI数据集3.RGB-D、TUM数据集二、ROS0.build_ros.sh 遇到的问题(1)rospack …

【C++】结构体应用案例 1

目录 1、缘起 2、案例描述 3、案例分析 4、代码清单 1 5、代码清单 2 6、总结 1、缘起 最近学习完了 C 语言的结构体相关知识点,如 结构体数组,结构体指针,结构体嵌套结构体 和 结构体做函数参数。本篇博客围绕着这些知识点&#xff0c…

【华为机试真题详解JAVA实现】—Sudoku

目录 一、题目描述 二、解题代码 一、题目描述 问题描述:数独(Sudoku)是一款大众喜爱的数字逻辑游戏。玩家需要根据9X9盘面上的已知数字,推算出所有剩余空格的数字,并且满足每一行、每一列、每一个3X3粗线宫内的数字均含1-9,并且不重复。 例如: 输入 输出