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

🎁个人主页:我们的五年

🔍系列专栏:每日一练

🌷追光的人,终会万丈光芒

 前言:

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

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

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

目录

目录

🏝1.问题描述:

​编辑

1.题目描述:

2.示范用例:

🏝2.实现代码:

🏝3.代码分析:

🏜步骤一:

🏜步骤二:

🏜步骤三:

❗️注意:

🚗总结:

🏝1.问题描述:

1.题目描述:

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

2.示范用例:

🏝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一直进行往后遍历。

❗️注意:

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

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

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

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

    NewHead=NewHead->next;

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

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

🚗总结:

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

最后,我也会把也会我不会的题目,或者我觉得值得重点关注的问题在我的博客进行分享,希望大家可以多多支持!

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

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

相关文章

JRT多服务器同步程序

之前的JRT只部署在一个服务器,实际运用可能会有数台、数十台、或者更多服务器。那么多台服务器就需要程序同步机制。这里借助Rsync同步,但是有个问题是Rsync同步jar之后他不知道是否需要重启站点,为此实现java控制台驱动Rsync,重定…

前端css中的transform(转换)的使用

前端css中的transform的使用 一、前言二、流程图三、举例(一)、平移1.平移,源码12.源码1运行效果(1).视频效果(2).截图效果 3.平移3d效果,源码24.源码2运行效果(1)、视频效果(2)、截…

深入了解计算机系统——利用循环展开对程序的优化

系列文章: 操作系统详解(1)——操作系统的作用 操作系统详解(2)——异常处理(Exception) 操作系统详解(3)——进程、并发和并行 操作系统详解(4)——进程控制(fork, waitpid, sleep, execve) 操作系统详解(5)——信号(Signal) 文章目录 一些概念CPE 初步优化消除不必…

python爬虫之爬取文本内容(2)

一、基本案例 #注意:需要将requests包换成2.27.1 #中文编码gbk也可能是utf-8 import requests #from bs4 import BeautifulSoupif __name__ __main__:url https://www.biqg.cc/book/6909/1.html#目标访问网站url#伪装头信息的引入header {"User-Agent"…

Golang | Leetcode Golang题解之第41题缺失的第一个正数

题目&#xff1a; 题解&#xff1a; func firstMissingPositive(nums []int) int {n : len(nums)for i : 0; i < n; i {for nums[i] > 0 && nums[i] < n && nums[nums[i]-1] ! nums[i] {nums[nums[i]-1], nums[i] nums[i], nums[nums[i]-1]}}for i …

Redis入门到通关之Redis实现Session共享

文章目录 ☃️前期概要☃️基于Session实现登录方案☃️现有方案存在的问题☃️Redis代替Session的业务流程❄️❄️设计key的结构❄️❄️设计key的具体细节❄️❄️整体访问流程 欢迎来到 请回答1024 的博客 &#x1f353;&#x1f353;&#x1f353;欢迎来到 请回答1024的博…

Windows 10 安装配置WSL2(Ubuntu 20.04)教程

Windows 10 安装配置WSL2&#xff08;Ubuntu 20.04&#xff09;教程 一、WSL简介 WSL&#xff08;Windows Subsystem for Linux&#xff09;是一个兼容层&#xff0c;允许在Windows 10上原生运行Linux二进制可执行文件。 二、安装WSL2 3.1 传统手动安装 更新系统&#xff…

OFDM同步技术

文章目录 前言一、OFDM 同步技术二、MATLAB 仿真1、STO 估计技术①、核心源码②、仿真结果 2、CFO 估计技术①、核心源码②、仿真结果 三、资源自取 前言 本文对 OFDM 同步技术以思维导图的形式呈现&#xff0c;有关仿真部分进行了讲解实现。 一、OFDM 同步技术 OFDM 同步技术…

前端工程化02-复习jQuery当中的插件开发

2、jQuery插件开发 在我们开发的时候、有时候jQuery提供的方法并不能满足我们的需求&#xff0c;如果我们想给jQuery扩展一些其他的方法&#xff0c;那这种情况下&#xff0c;可能会需要写一个插件 jQurey官网&#xff1a;jquery.com 例如一些、图片懒加载插件、滚动的插件、…

阿里云效中的Story Point是什么,代表的是什么意思,该怎么填

文章目录 Story Point是什么一个合理的Point应该能让团队的其他成员相对准确的评估任务难度根据自己对任务难度的分析对比团队Point标准评估一个任务是多少Point点时建议三个人评估 这是我阅读并参考的文章 中文翻译Story Point 故事 点&#xff08;观点&#xff0c;论点&#…

GDPU unity游戏开发 碰撞体与关节

让你设计的角色跑起来吧&#xff0c;可以是动画&#xff0c;也可以是碰撞器的运动。 运动小车 找到小车素材&#xff0c;导入到层级面板。然后可以新建一个地面让小车在上面运动&#xff0c;新建一个方块当障碍物。 摆放好后&#xff0c;要加组件。记住&#xff0c;在unity中运…

多商家AI智能名片商城系统(开源版)——构建高效数字化商业新生态

一、项目概述 1、项目背景 1&#xff09;起源 随着数字化时代的快速发展&#xff0c;传统名片和商城系统已经难以满足企业日益增长的需求。商家需要更高效、更智能的方式来展示自己的产品和服务&#xff0c;与消费者进行互动和交易。同时&#xff0c;开源技术的普及也为开发…

HTML的学习-通过创建相册WEB学习HTML-第二部分

文章目录 二、学习开始3.6、form元素示例&#xff1a;添加form元素示例&#xff1a;action属性添加到form属性中 3.7、input元素示例&#xff1a;在input属性中添加参数 3.8、button元素示例&#xff1a;在button中添加type元素示例&#xff1a;定义单选按钮radio 3.9、id属性示…

easyExcel快速入门

目录 &#x1f9c2;1.简单介绍 &#x1f32d;2.快速入门 &#x1f953;1.导入依赖 &#x1f37f;2.导出到excel &#x1f38f;3.读入数据 &#x1f389;4.下载 1.简单介绍 传统操作Excel大多都是利用Apach POl进行操作的,但是POI框架并不完善,使用过程非常繁琐且有较多…

盛水最多的容器 ---- 双指针

题目链接 题目: 分析: 最大容积 即使就是最大面积, 长为下标之差, 宽为两下标对应值的最小值解法一: 暴力枚举: 将每两个数之间的面积都求出来, 找最大值, 时间复杂度较高解法二: 假设我们的数组是[6, 2, 5, 4], 我们先假设最左边和最右边, 即6 和 4 之间是最大面积长a*宽b此…

nginx配置ip_hash负载均衡策略

一、nginx配置ip_hash负载均衡策略 nginx默认的负载均衡策略为轮询&#xff0c;某些场景需要使用ip_hash负载策略&#xff0c;即&#xff1a;同一个ip地址&#xff0c;永远访问nginx后面同一台tomcat。配置示例如下&#xff0c;主要是设置ip_hash&#xff1a; upstream www.ab…

Pandas数据分析小技巧

Pandas数据分析小技巧&#xff1a;提升数据处理效率与准确性的秘诀 Pandas是一个强大的Python数据分析库&#xff0c;它提供了快速、灵活且富有表现力的数据结构&#xff0c;使得数据清洗、转换、分析等操作变得简单而高效。本文将介绍一些Pandas数据分析的小技巧&#xff0c;…

三招教你成为朋友圈运营高手,赶紧get起来!

朋友圈作为一个重要的营销推广渠道&#xff0c;是能够为我们带来很多收益的。今天就给大家分享朋友圈运营的三个技巧&#xff0c;快快Get起来吧&#xff01; 第一招&#xff1a;明确人设定位 要在朋友圈里脱颖而出&#xff0c;首先我们需要明确自己的人设定位。选择一个与自己…

【Spring】IOC/DI中常用的注解@Order与@DependsOn

目录 1、Order 注解改变Bean自动注入的顺序 1.1、了解SpringBootTest注解 1.2、Order 注解改变Bean自动注入的顺序 2、DependsOn 改变Bean的创建顺序 1、Order 注解改变Bean自动注入的顺序 在sping中&#xff0c;通过IOC&#xff08;控制反转&#xff09;和DI&#xff08;依…

文本向量化模型新突破——acge_text_embedding勇夺C-MTEB榜首

在人工智能的浪潮中&#xff0c;以GPT4、Claude3、Llama 3等大型语言模型&#xff08;LLM&#xff09;无疑是最引人注目的潮头。这些模型通过在海量数据上的预训练&#xff0c;学习到了丰富的语言知识和模式&#xff0c;展现了出惊人的能力。在支撑这些大型语言模型应用落地方面…