【LeetCode训练营】反转链表 移除链表元素 详细图解 203,206

news2025/1/19 14:12:41

  

  • 💌 博客内容:LeetCode 训练营 

  • 😀 作  者:陈大大陈

  • 🚀 个人简介:一个正在努力学技术的准前端,专注基础和实战分享 ,欢迎私信!

  • 💖 欢迎大家:这里是CSDN,我总结知识和写笔记的地方,喜欢的话请三连,有问题请私信 😘 😘 😘

 移除链表元素

203. 移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == 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
输出:[]

提示:

列表中的节点数目在范围 [0, 104] 内

1 <= Node.val <= 50

0 <= val <= 50

思路

  • 题目思路:要移除值为val的元素,就涉及到了单链表的头删和中间位置删除,这就需要我们定义一个prev指针指向要删除元素的前一个元素,然后让它指向要删除元素的后一个元素。
  • prev指针一开始定义为NULL,当链表当前位置即为要删除元素的位置且prev指针为空时,就需要用到单链表头删的知识来考虑这一种情况。
  • 不需要删除的情况就让prev指针指向tail指针的位置,让tail指向下一个位置。
  • 需要删除且不为头删时,写法就是单链表中间删除的写法,让前一个指针指向删除位置的下一个,把要删除的位置free掉即可。

源码 

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

反转链表 

206. 反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1:

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

思路

 反转单链表,我采用头插法,对每一个结点采用头插。

定义一个中间变量temp,将cur->next赋值给它,保存它的值,便于一会使用。

定义一个pre为空,让cur->next指向它。一开始的情况是这样的。

之后我们将cur的值赋给pre,让cur指向它的下一个。

可它的next已经变成pre了,没法直接 cur=cur->next。

这是我们上面定义的temp就派上用场了。

将temp的值赋给cur。

这时的情况变成了这样。

 这样到最后,情况会变成这样。

 

所以循环的条件应该是while(cur)。 

源码

struct ListNode* reverseList(struct ListNode* head){
struct ListNode*cur=head,*pre=NULL;
while(cur)
{
    struct ListNode*temp=cur->next;
    cur->next=pre;
    pre=cur;
    cur=temp;
}
return pre;
}

如果大家有更好的方法,请一定要私信教教我!求大佬带带。

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

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

相关文章

SpringMVC实现文件上传和下载和Json的简单实用

目录 SpringMVC实现文件上传和下载 1、文件下载 2、文件上传 &#xff08;1&#xff09;文件上传操作的分析 &#xff08;2&#xff09;实现步骤 (3&#xff09;解决文件重名覆盖问题 Json的简单使用 1、Json概述 2、Json的语法格式 3、Jackson的QuickStart SpringMVC…

【C++STL】map

文章目录 一. map的介绍二. map的使用结束语 一. map的介绍 map是关联容器&#xff0c;它按照特定的次序&#xff08;按照key来比较&#xff09;存储由键值key和值value组合而成的元素在map中&#xff0c;键值key通常用于排序和唯一地标识元素&#xff0c;而value中存储与此键值…

OSI七层模型、TCP/IP四层模型

OSI七层模型和TCP/IP四层模型 OSI七层模型 物理层&#xff1a;底层数据传输&#xff0c;如网线、网卡标准数据链路层&#xff1a;定义数据基本格式&#xff0c;如何传输如何标识&#xff1b;如网卡MAC地址网络层&#xff1a;定义IP地址&#xff0c;定义路由功能&#xff1b;如…

【中级软件设计师】—(针对上午题)二十三种设计模式(三十九)

【中级软件设计师】—&#xff08;针对上午题&#xff09;二十三种设计模式&#xff08;三十九&#xff09; 一、设计模式的分类 背背背 1 二、创建型设计模式&#xff08;5种&#xff09; 三、简单工厂模式 简单工厂模式代码实现如下&#xff1a; /*** author&#xff1a;Ca…

CentOS分区挂载 fdisk、parted方式解析

1 介绍 在linux中&#xff0c;通常会将持久化数据保存到硬盘当中&#xff0c;但是硬盘一把会比较大&#xff0c;因此我们为了方便管理&#xff0c;会将一个硬盘分成多个逻辑硬盘&#xff0c;称之为分区。 为了能够让分区中的文件使得能让操作系统处理&#xff0c;则需要对分区…

Java阶段二Day11

Java阶段二Day11 文章目录 Java阶段二Day11DQL主键与外键外键约束多对多关系内连接外连接自连接 JDBC核心接口JDBC连接的基本流程 教师总结主键与外键外键约束结论:关联关系中通常不适用外键约束。 多对多关系多对多关联查询例 练习题干答案 内连接语法例 外连接例 自连接定义场…

研报精选230427

目录 【行业230427东方金诚】有色金属行业信用风险回顾与2023年展望 【行业230427头豹研究院】2023年中国汽车安全气囊行业词条报告 【行业230427头豹研究院】2023年中国钠离子负极材料行业词条报告 【个股230427开源证券_佳禾食品】公司首次覆盖报告&#xff1a;植脂末龙头再启…

小匠物联出席宁波第五届家电产业数字化对接会助推家电产业数智化

宁波的家电资源与市场充足&#xff0c;特别是小家电&#xff0c;涉及20多个细分行业、近千个品种&#xff0c;其中10多个细分行业小家电产量一直位居全国或全球首列。但受原材料上涨等多重因素的影响&#xff0c;作为宁波市传统优势产业的家电产业也未能避免&#xff0c;产业数…

ldif 数据转成正确的组织结构再探

上次文章最后有说到按照之前的思路来转化组织结构是有坑的&#xff0c;我们现在还只是对接 AD域&#xff0c;ldap 协议的其他产品在细节上还会有些许不同 我们是不能直接粗暴的认为 cn 就是对应标识一个用户&#xff0c; cn 是 common name 的意思&#xff0c;他也可以表示我们…

【LeetCode】(力扣) c/c++刷题-145. 二叉树的后序遍历

题目&#xff1a; 给你一棵二叉树的根节点 root &#xff0c;返回其节点值的 后序遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[3,2,1] 示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[] 示例 3&#xff1a; 输入&a…

线性表的链式存储结构与操作 题目编号:455

题目描述 评论 请你定义一个链表&#xff0c;可以对链表进行“在某个元素之前插入一些元素”、“删除某个位置的元素”、“查找某元素”、“获取某个位置的元素”、“遍历输出所有元素”、“求链表的长度”等操作。键盘输入一些命令&#xff0c;可以执行上述操作。本题中&…

电控针阀和手动可变泄漏阀组合在超高真空度精密PID控制中的应用

摘要&#xff1a;超高真空度的控制普遍采用具有极小开度的可变泄漏阀对进气流量进行微小调节。目前常用的手动可变泄漏阀无法进行超高真空度的自动控制且不准确&#xff0c;电控可变泄漏阀尽管可以实现自动控制但价格昂贵。为了实现自动控制且降低成本&#xff0c;本文提出了手…

线性表的顺序存储结构与操作 题目编号:454

题目描述 请你定义一个顺序表&#xff0c;可以对顺序表进行如下操作&#xff1a; 在某个元素之前插入一些元素 删除某个位置的元素 查找某元素 获取某个位置的元素 遍历输出所有元素 键盘输入一些命令&#xff0c;可以执行上述操作。本题中&#xff0c;顺序表元素为整数&…

【BIM+GIS】Supernap加载实景三维倾斜摄影模型

OSGB是常见的倾斜模型格式,本文讲述如何在Supernap中加载实景三维倾斜摄影模型OSGB。 文章目录 一、生成配置文件二、加载倾斜模型1. 新建场景2. 添加模型3. 高程调整一、生成配置文件 点击【三维数据】→【数据管理】→【生成配置文件】。 参数设置如下: 源路径:选择倾斜模…

荔枝派Zero(全志V3S)开启mplayer,播放音视频

文章目录 前言一、buildroot 配置及编译1、开启 ALSA 和 MPLAY2、编译 二、拷贝到到 SD 卡1、将 rootfs.tar 解压缩到 SD 卡 rootfs 分区②、将 mp4 文件和 mp3 文件拷贝到 SD 卡 rootfs 分区 三、测试1、mplayer 使用2、mplayer 播放音频3、mplayer 播放视频 前言 mplayer 是…

华为在软件工具生态埋下多颗“种子”,静候国产软件产业萌芽

文丨智能相对论 作者丨沈浪 当代的数字经济大厦由各种各样的软件一块一块地搭建起来。然而&#xff0c;站在国内软件行业的中心&#xff0c;热闹的大多是来自上层的软件应用&#xff0c;而沉寂的却总是底层又难又基础的领域&#xff0c;比如软件开发。 软件开发&#xff0c;…

初始新能源汽车

文章目录 电动汽车的三级模块体系VCU&#xff08;整车控制器&#xff09;MCU&#xff08;电机控制器&#xff09;电池包和BMS&#xff08;电池管理系统&#xff09;电动汽车的大三电电动汽车的小三电电动汽车的模块组成 电动汽车的三级模块体系 总体上讲&#xff0c;整个新能源…

牛客刷题篇:客似云来 和 剪花布条(Java)

目录 题目一&#xff1a;客似云来 输入描述 输出描述 解题思路 代码 题目二&#xff1a;剪花布条 输入描述 输出描述 解题思路 代码 题目一&#xff1a;客似云来 链接&#xff1a;客似云来 NowCoder开了一家早餐店&#xff0c;这家店的客人都有个奇怪的癖好&#xff…

算法刷题|1143.最长公共子序列、1035.不相交的线、53.最大子数组和

最长公共子序列 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串在不改变字符的相对顺序的情况下删除某些字符&a…

跨子网通信【路由通信。配置路由】

路由通信条件是&#xff1a;服务器多网卡 or 单网卡多IP 查看路由表 route -n设置一网卡多IP 进行网络配置 进入setup中&#xff0c;选择网络配置 setup选择设备配置 去除DHCP动态协议 进来后&#xff0c;可能会发现无法对静态IP和子网掩码进行编辑&#xff0c;是因为你开启…