203.移除链表元素

第一种思路

循环遍历整个链表

定义两个指针:prev,cur

如果cur是要删除的节点,prev->cur->next,然后free(cur)

但是注意每次都要新定义一个节点del,用来free,不影响原来的cur节点往下循环

更新cur和prev

但是需要注意如果删除的是头节点,就要特殊处理,画图带上指针,情况分析,一目了然。

思路一代码:

cs 复制代码
struct ListNode* removeElements(struct ListNode* head, int val) {
   struct ListNode *cur =head;
   struct ListNode *prev = NULL;
   while(cur)
   {
       struct ListNode *del = cur;
       if(del->val == val)
       {
           cur = cur->next;
           free(del);
            //如果是头节点,需要更新头节点
            if(prev == NULL)
            {
                head = cur;
            }
             else
            {
                prev->next = cur;
            }
       }
       else
        {
            prev = cur;
            cur = cur->next;
        }      
   }
   return head;
}

第二种思路:

创建新链表,不等于val的节点尾插到新链表,返回新链表

这种方式需要画出详细的过程图,否认坑很多

需要注意的点:

1、链表为空

2、最后一个节点是要不要的节点,涉及到新链表的最后一个节点的下一个节点是野指针问题,这个可以到VS上进行调试

第二种思路代码:

cs 复制代码
struct ListNode* removeElements(struct ListNode* head, int val) {
   
   struct ListNode *cur = head;
   struct ListNode *newNode = NULL, *tail =NULL;
   while(cur)
   {
       //不等于值,尾插
       if(cur->val != val)
       {
           //头节点为空
           if(tail == NULL)
           {
               tail = newNode = cur;
           }
           else
           {
               tail->next = cur;
               tail = tail->next;
           }
        cur = cur->next;
       }
       else
       {
           struct ListNode *del = cur;
           cur = cur->next;
           free(del);
       }
   //如果删除的是最后一个节点
   //会出现野指针的问题
    //对空链表进行检查
    if(tail)
        tail->next = NULL;
   }  
   return newNode;
}
相关推荐
_Itachi__20 分钟前
LeetCode 热题 100 74. 搜索二维矩阵
算法·leetcode·矩阵
不忘不弃21 分钟前
计算矩阵A和B的乘积
线性代数·算法·矩阵
不爱写代码的玉子24 分钟前
HALCON透视矩阵
人工智能·深度学习·线性代数·算法·计算机视觉·矩阵·c#
Java 技术轻分享30 分钟前
《树数据结构解析:核心概念、类型特性、应用场景及选择策略》
数据结构·算法·二叉树··都差速
芜湖xin1 小时前
【题解-洛谷】P1706 全排列问题
算法·dfs
chao_7892 小时前
链表题解——两两交换链表中的节点【LeetCode】
数据结构·python·leetcode·链表
曦月逸霜2 小时前
第34次CCF-CSP认证真题解析(目标300分做法)
数据结构·c++·算法
海的诗篇_3 小时前
移除元素-JavaScript【算法学习day.04】
javascript·学习·算法
自动驾驶小卡4 小时前
A*算法实现原理以及实现步骤(C++)
算法