203.移除链表元素

第一种思路

循环遍历整个链表

定义两个指针:prev,cur

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

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

更新cur和prev

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

思路一代码:


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上进行调试

第二种思路代码:


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;
}

相关推荐

  1. 【LeetCode】203. 元素

    2024-01-25 12:00:03       56 阅读
  2. leetcode203. 元素

    2024-01-25 12:00:03       59 阅读
  3. Leetcode 203 元素

    2024-01-25 12:00:03       62 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-25 12:00:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-25 12:00:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-25 12:00:03       87 阅读
  4. Python语言-面向对象

    2024-01-25 12:00:03       96 阅读

热门阅读

  1. google-webrtc 原理

    2024-01-25 12:00:03       54 阅读
  2. Spark累加器LongAccumulator

    2024-01-25 12:00:03       51 阅读
  3. 【笔记】Helm-4 最佳实践-依赖

    2024-01-25 12:00:03       59 阅读
  4. harmonyOS app 开发环境配置流程

    2024-01-25 12:00:03       52 阅读
  5. 安卓MediaRecorder(4)视频采集编码写入详细源码分析

    2024-01-25 12:00:03       68 阅读
  6. Jenkins相关

    2024-01-25 12:00:03       58 阅读