203.移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Definition for singly-linked list.
struct ListNode {
      int val;
      struct ListNode *next;
 };

 typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) {
    ListNode* newhead,*newtail;
    newhead=newtail=NULL;
    ListNode* pcur=head;
    while(pcur)
    {
        if(pcur->val != val)
        {
            //新链表为空
            if(newhead==NULL)
            {
                newhead=newtail=pcur;
            }else
            {
                //链表不为空
                newtail->next=pcur;
                newtail=newtail->next;
            }
        }
        pcur=pcur->next;
    }
    if(newtail)
    {
        newtail->next=NULL;
    }
    return newhead;
}

我们创建一个新链表,ListNode* newhead,*newtail分别表示这个新链表的头和尾。把新链表置为空
从头节点开始遍历,while循环判断条件为是否随着遍历走向空节点。在遍历中节点中的数据不等于要移除的值就把这些值放入链表中。但注意要区分情况,如果新链表为空就直接放入链表中,如果链表不为空就尾插。

到这里可能就以为做完了,但是还有一个坑。就拿上面的第一个示例来说当我们把5这一节点放入新链表中时,5这一节点还连接着下一节点也就是6这一节点。所以我们要把新链表的最后一个节点的下一个节点置为空。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孤寂大仙v

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值