203. 移除链表元素-c语言
创始人
2025-05-29 09:28:26
0

题目来源:力扣

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

本题有两种解决方法

目录

代码1:

 代码2


示例 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
输出:[]

代码1:
 

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

 思路:我们逐段进行分析

我们使用两个指针,一前一后

 使cur先指向头,prev在cur之前(最开始为空),然后我们对cur的val进行判断,如果cur的val不等于题给的val,说明不需要删除该节点,我们让prev=cur,然后cur指向next即可,若cur的val与题给val相等,说明需要删除节点,我们让prev的next指向cur的next(prev在cur之前),然后我们释放掉cur,接着让cur指向prev的next即可,如果我们此时提交,就会发现有错误,示例3是过不了的,我们对代码进行解析,发现最开始时cur的val就等于val,此时进入循环,prev的next需要进行指向,但此时的prev为空,所以会出现空指针问题,也就是说,我们有可能需要进行头删,所以我们再次进行判断,即else里我们加的if,如果prev为空,我们进行头删。让head指向cur的next,然后释放cur,cur再指向head即可

 代码2

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

思路:

我们创建一个新节点为新的头节点,将符合条件的节点尾插到新节点,最后返回即可

我们创建newhead和cur,还有tail节点,tail是用来指向newhead的尾节点,不然每次我们都要遍历新链表,我们对原链表进行遍历,如果val不等于cur的val,说明要将该节点尾插到newhead,不过在尾插前,我们要先判断是否为第一个节点,即newhead和tail都为NULL,此时我们要单独处理,其余情况我们将tail的next指向cur,然后tail向后移动即可,最后再让cur向后移动,如果不等于,说明要删除该节点,我们先保存cur的next,然后释放cur,cur指向next即可,我们此时提交,会出现错误,如果最后一个节点是我们要删除的,那么最后tail的next是有问题的,所以我们最后单独处理,将tail的next置为空即可,我们再次提交的话,还是会出现问题,空链表无法处理,我们对其单独处理,即前三行我屏蔽的代码,接着再次提交,示例3出现问题,我们分析知道,全部删除的话,最后newhead和tail都为空,所以我们最后对tail进行判断,如果tail不为空,也就是说我们的newhead是有节点的,我们将tail的next置为空,否则我们直接返回newhead,此时newhead为空,也就是空链表和全删除的情况我们都可以处理,所以我们删除前三行单独处理空链表的代码即可(不删也无所谓)

 

相关内容

热门资讯

FIBA期待杨瀚森表现 最新实... 北京时间6月25日消息,FIBA国际篮联公布了最新一期世界杯预选赛亚太区球队实力榜,中国男篮排在澳大...
收评:创业板指放量反弹涨2.8... 市场冲高回落后,再度震荡拉升。黄白线分化明显,权重股走势较强。量能明显放大,沪深两市成交额3.59万...
巨头财报引爆A股存储芯片板块,... 当地时间6月24日美股盘后, 美光科技(MU.US)公布截至5月31日的2026财年第三财季财报,业...
银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...