【单链表】LeetCode:203.移除链表元素

这篇具有很好参考价值的文章主要介绍了【单链表】LeetCode:203.移除链表元素。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🎁个人主页:我们的五年

🔍系列专栏:每日一练

🌷追光的人,终会万丈光芒【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

 前言:

该题是数据结构,单链表的一道基本题,刚刚准备学习数据结构,或者正在学习数据结构的可以学习一下。

题目链接:203. 移除链表元素 - 力扣(LeetCode)

最后喜欢的铁子们可以三连,谢谢大家的支持!祝大家天天开心!

目录

目录

🏝1.问题描述:

​编辑

1.题目描述:

2.示范用例:

🏝2.实现代码:

🏝3.代码分析:

🏜步骤一:

🏜步骤二:

🏜步骤三:

❗️注意:

🚗总结:

🏝1.问题描述:

【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

1.题目描述:

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

2.示范用例:

【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

🏝2.实现代码:

LeetCode以函数的形式给出:

节点结构体:

struct ListNode{

        int val;

        struct ListNode* next;

};

传递也是传递的是指向头节点的指针


 typedef struct ListNode ListNode;    //重定义struct ListNode
struct ListNode* removeElements(struct ListNode* head, int val) {
    
    //对链表进行判空处理
    if(head==NULL)
        return head;
    
    //定义新节点的头和尾,一开始头节点等于尾节点
    //定义头节点,可以把后面不等于val的节点直接进行尾插,不要进行判空处理。
    ListNode *NewHead,*NewTail;
    NewHead=NewTail=(ListNode*)malloc(sizeof(ListNode));

    //pcur指针对原链表进行遍历
    ListNode *pcur=head;
    while(pcur)
    {
        //对满足题意的节点进行尾插,NewTail每次尾插要记得往后面移动
        if(pcur->val!=val)
        {
            NewTail->next=pcur;
            NewTail=NewTail->next;
        }
        //pcur每次都向后进行移动
        pcur=pcur->next;
    }
    
    //最后如果尾节点的next指针不为NULL,那么需要我们自己去置为NULL
    //不然又会和后面的节点进行关联
    if(NewTail->next)
        NewTail->next=NULL;

    //最后返回头结点的next指针
    NewHead=NewHead->next;
    return NewHead;
}

🏝3.代码分析:

🏜步骤一:

    if(head==NULL)
        return head;

先对节点进行判空处理,因为节点数目可能为0,如果head为NULL,那么直接返回head。

如果不进行判空处理,后面可能会对NULL进行解应用,出现错误。

🏜步骤二:

    ListNode *NewHead,*NewTail;
    NewHead=NewTail=(ListNode*)malloc(sizeof(ListNode));

然后创建一个头节点,一个尾节点。通过NewHead->next我们可以找到第一个节点,然后返回这一个节点。NewTail是每次尾插时要用到的,在尾插的过程中,我们把NewTail的next

指针置为指向新插入的节点的指针,然后让NewTail变为新插入的节点。

🔍这样先申请一个黑头节点,我们就不要对新的头节点进行判空处理了。

🏜步骤三:

    ListNode *pcur=head;
    while(pcur)
    {
        //对满足题意的节点进行尾插,NewTail每次尾插要记得往后面移动
        if(pcur->val!=val)
        {
            NewTail->next=pcur;
            NewTail=NewTail->next;
        }
        //pcur每次都向后进行移动
        pcur=pcur->next;
    }
    改循环就是对节点val的值进行判断,然后进行尾插的一个过程,如果符合题意的节点我们就尾插,把NewTail的next变为pcur,新的NewTail变为pcur。

pcur一直进行往后遍历。

❗️注意:

上面三个步骤完成以后,这题差不多就完成,但是把上面的代码直接提交,我们会发现没有通过!

【单链表】LeetCode:203.移除链表元素,每日一练,leetcode,链表,算法,c语言,数据结构,c++,c#

这是因为我们没有对尾节点的next进行处理,如果我们不进行处理,那么如果尾节点的next不是NULL,这样还是会与后面的节点进行关联,所以测试用例才会多出一个6.

    if(NewTail->next)
        NewTail->next=NULL;

但是如果我们在尾节点加上这样一句话,我们就可以避免这种情况,不要多输出后面的节点。

    NewHead=NewHead->next;

最后我们返回NewHead的next指针,也就是满足题意的第一个节点就可以通过题目用例了。

因为开始我们动态申请了一块空间,我们也可以先保存第一个节点,释放以后,再进行return操作。

🚗总结:

谢该题时,我们如果只是对空间情况进行考虑是远远不够的,我们还需要对头部2进行分析,对尾部进行分析,这样我们能尽可能的满足题目要求,不会出现其他小的错误。

最后,我也会把也会我不会的题目,或者我觉得值得重点关注的问题在我的博客进行分享,希望大家可以多多支持!文章来源地址https://www.toymoban.com/news/detail-858703.html

到了这里,关于【单链表】LeetCode:203.移除链表元素的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Leetcode: 203. 移除链表元素

    题目 给你一个链表的头节点  head  和一个整数  val  ,请你删除链表中所有满足  Node.val == val  的节点,并返回  新的头节点  。 难度: 简单 题目链接:203. 移除链表元素 示例 1: 示例 2: 示例 3: 方法一:  题目解析: 遍历链表,删除指定元素(val) 代码展示 删除元素的

    2024年02月04日
    浏览(32)
  • 【LeetCode】203. 移除链表元素

    leetcode链接 203. 移除链表元素

    2024年01月18日
    浏览(30)
  • 【 LeetCode题解 】203. 移除链表元素

    题目链接 : https://leetcode.cn/problems/remove-linked-list-elements/ 博客主页链接:Duck Bro 博客主页 关注博主,后期持续更新系列文章 ***感谢观看,希望对你有所帮助*** 🧐方案一 方案1:主要思路遇到val就删除,分为头删和中间删除两种情况。 当val在链表中间时,遇到val就删除链表中

    2024年02月09日
    浏览(33)
  • LeetCode 刷题 数据结构 链表 203 移除链表元素

    Given the  head  of a linked list and an integer  val , remove all the nodes of the linked list that has  Node.val == val , and return  the new head . Example 1: Example 2: Example 3: Constraints: The number of nodes in the list is in the range  [0, 104] . 1 = Node.val = 50 0 = val = 50 今天leetcode的中文官网比较卡,所以是登录官网进行

    2024年02月14日
    浏览(27)
  • Leetcode刷题笔记题解(C++):203. 移除链表元素

    思路:不同的情况出现了,就是第一个节点要是为等于val的节点,可以新建一个节点,并next指向head,这样就可以遍历新的链表来删除节点

    2024年02月22日
    浏览(29)
  • 【代码随想录 | Leetcode | 第五天】链表 | 移除链表元素 | 设计链表 | 203-707

    欢迎来到小K的Leetcode|代码随想录|专题化专栏,今天将为大家带来移除链表元素和设计链表的分享 ✨ ✨题目链接点这里 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。 示例 1: 示例 2: 示例 3: 提示: 列表中

    2024年02月16日
    浏览(45)
  • 【Leetcode60天带刷】day03链表——203. 移除链表元素,707.设计链表,206. 反转链表

    链表就像一串小火车,有一节一节的车厢,每个车厢都叫做一个节点。  单链表:每个链表车厢里有两个内容,一个放的是真正的数据,另一个放的是下一节车厢的编号。 双链表:每个链表车厢里有三个内容,一个真正数据,一个下一个车厢的编号,还有一个上一节车厢的编

    2024年02月06日
    浏览(35)
  • 算法刷题营【Day3】:: 链表篇:单链表结点删除思路:一题辨别哨兵结点的优势(删除有奇效):203. 移除链表元素

    本内容是笔者结合《代码随想录》总结所得,记录学习过程,分享知识! 目录: 1. 开篇例题:203. 移除链表元素 2. 题解参考 - - 2.1 方法一:原表操作(不含哨兵结点) - - 2.2 方法二:虚设哨兵结点辅助法 - - 2.3 方法三:递归法 3. 单链表结点删除思路 4. 方法思路点拨:原表操

    2024年02月06日
    浏览(35)
  • 【LeetCode题目详解】 203. 移除链表元素707. 设计链表206. 反转链表 day3(补)

    题意:删除链表中等于给定值 val 的所有节点。 示例 1: 输入:head = [1,2,6,3,4,5,6], val = 6 输出:[1,2,3,4,5] 示例 2: 输入:head = [], val = 1 输出:[] 示例 3: 输入:head = [7,7,7,7], val = 7 输出:[] 看到这道题就想到了链表 这道题有两种写法,涉及如下链表操作的两种方式: 直接使用

    2024年02月16日
    浏览(30)
  • 刷题日记 Day 3 : Leetcode 203 . 移除链表元素、Leetcode 707 . 设计链表、Lettcode 206 . 反转链表

    本篇文章 , 是在代码随想录 60 天编程挑战的基础上进行的题目讲解 参与链接在此 : https://programmercarl.com/other/xunlianying.html 大家好 , 这个专栏 , 给大家带来的是 60 天刷题强训 . 最令大家头疼的事就是刷题了 , 题目又臭又长又抽象 , 有的题读都读不懂 , 更别说做了 . 所以 , 这个

    2023年04月09日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包