【数据结构与算法】203.移除链表元素(LeetCode)图文详解

移除链表元素

题目传送门

思路一:遍历链表

定义一个指针prev遍历整个数组 如果他下一个节点的val值为val,就移除这个节点,让prev的next指针指向被删除的下一个节点,然后prev后移,直到prev的next指针为空

按照这个思路,有以下代码

c 复制代码
struct ListNode* prev;
while(prev!=NULL)
{
    if(prev->next->val=val)
    {
        struct ListNode* del=prev->next;
        prev->next=del->next;
        free(del);//释放内存时,必须用原指针 
    }
    else
    {
        prev=prev->next;
    }
}

我们再来看特殊的情况

链表为空时

直接返回空指针

c 复制代码
if(head==NULL)
{
    return NULL;
}

头节点的val值为被删除的元素时

c 复制代码
while(head!=NULL&&head->val==val)
{
    struct ListNode*del=head;
    head=head->next;
    free(del);
    
}

完整代码如下

c 复制代码
struct ListNode* removeElements(struct ListNode* head, int val) {

    while(head!=NULL&&head->val==val) 
    {
        struct ListNode*del=head;
        head=head->next;
        free(del);
    }
    if(head==NULL)
    {
        return NULL;
    }
    struct ListNode*prev = head;
    
     while(prev->next!=NULL)
    {
        
        if(prev->next->val==val)
        {
            struct ListNode* del=prev->next;
            prev->next=prev->next->next;
            free(del);
        }
        else{
        prev=prev->next;
        }
            
    }
        return head;    
}

思路二:创建新的链表

本质:定义一个指针pcur 让他去遍历原链表 如果pcur->val不为val,就把他尾插到新的链表中

c 复制代码
struct ListNode* removeElements(struct ListNode* head, int val){
	//创建新的头节点 尾节点
    struct ListNode* NewHead,*NewTail;
    NewHead=NULL;
    NewTail=NULL;
    struct ListNode*pcur=head;
    //遍历原链表
    while(pcur)
    {
        
        //找值不为val的节点,尾插到新链表中
        if(pcur->val!=val)
        {
            //链表为空(第一次插入)
            if(NewHead==NULL)
            {
                NewHead = NewTail = pcur;
            }
            //链表不为空
            else
            {
                NewTail->next=pcur;//pcur插入到NewTail后 成为新的尾节点
                NewTail=NewTail->next;
            }
            
            
        }
        pcur=pcur->next;
        
        if(NewTail!=NULL)
           NewTail->next=NULL;//一定要置为空,不然像示例一中最后的6 也会输出 因为5对应的next指针指向的是6这个节点
    }        
    return NewHead;
}
相关推荐
小庞在加油31 分钟前
Apollo源码架构解析---附C++代码设计示例
开发语言·c++·架构·自动驾驶·apollo
体系结构论文研讨会36 分钟前
多项式环及Rq的含义
算法
智驱力人工智能1 小时前
极端高温下的智慧出行:危险检测与救援
人工智能·算法·安全·行为识别·智能巡航·高温预警·高温监测
森焱森1 小时前
60 美元玩转 Li-Fi —— 开源 OpenVLC 平台入门(附 BeagleBone Black 驱动简单解析)
c语言·单片机·算法·架构·开源
专注VB编程开发20年1 小时前
各版本操作系统对.NET支持情况(250707更新)
开发语言·前端·ide·vscode·.net
我喜欢就喜欢1 小时前
RapidFuzz-CPP:高效字符串相似度计算的C++利器
开发语言·c++
千帐灯无此声1 小时前
Linux 测开:日志分析 + 定位 Bug
linux·c语言·c++·bug
莫彩1 小时前
【Modern C++ Part7】_创建对象时使用()和{}的区别
开发语言·c++
星光54221 小时前
飞算JavaAI:给Java开发装上“智能引擎”的超级助手
java·开发语言
课堂剪切板2 小时前
ch07 题解
算法·深度优先