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为空,也就是空链表和全删除的情况我们都可以处理,所以我们删除前三行单独处理空链表的代码即可(不删也无所谓)

 

相关内容

热门资讯

企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...
002808,或被终止上市! 【导读】因触及财务类退市指标,*ST恒久或被终止上市 中国基金报记者 李智 又一A股或被终止上市。 ...
院士团队掌舵,溧阳这家企业已完... 近日,溧阳天目先导电池材料科技有限公司(下称“天目先导”)官宣完成B轮融资,投资方包括知卓创新资本、...
工商银行全新推出“工盈研选”品... 深圳商报·读创客户端记者 詹钰叶 近日,工商银行重磅推出「工盈研选」基金销售服务品牌,以客户盈利为核...
和讯信息胡云龙:逼空走势,周五... 今天市场出现逼空走势,场内投资者因持有筹码而尤为受益。五一前布局的投资者当前收获颇丰。然而,随着上证...
今晚,油价上调! 4月21日国内成品油价格下调以来,国际市场原油价格剧烈震荡,前期大幅上涨后近日有所回落,本次调价的前...
南方东英旗下两倍做多海力士,成... 【导读】南方东英旗下两倍做多海力士,成为全球最大的个股杠杆及反向产品 中国基金报记者 伊万 人工智能...
原创 金... 黄金,这东西从古至今就没离开过中国人的生活。从老辈人压箱底的小黄鱼,到如今年轻人结婚绕不开的“三金”...