当前位置: 首页 > news >正文

力扣203.移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。

方法一:常规做。但是需要先判断头节点是否需要删除

class Solution 
{
public:
    ListNode* removeElements(ListNode* head, int val) 
    {
        while(head!=nullptr&&head->val==val)
        {
            ListNode*tmp=head;
            head=head->next;
            delete tmp;
        }

        ListNode*cur=head;
        while(cur!=nullptr&&cur->next!=nullptr)
        {
            if(cur->next->val==val)
            {
                ListNode*tmp=cur->next;
                cur->next=cur->next->next;
                delete tmp;
            }
            else
            {
                cur=cur->next;
            }
        }
        return head;
    }
};

一个小细节:为什么while的条件是cur!=nullptr&&cur->next!=nullptr?这两个看似重复的条件实际上是不一样的。因为有一种可能是,链表中所有节点的值都为val,那么这时cur就为nullptr了。cur->next!=nullptr好理解,就是正常的终止条件(最后一个节点)

方法二:能不能归为同一种情况呢?是可以的。我们构造一个新的头节点,让这个新的头节点指向原来的头节点即可。

class Solution 
{
public:
    ListNode* removeElements(ListNode* head, int val) 
    {
        ListNode*virtualhead=new ListNode(0);
        virtualhead->next=head;

        ListNode*cur=virtualhead;
        while(cur!=nullptr&&cur->next!=nullptr)
        {
            if(cur->next->val==val)
            {
                ListNode*tmp=cur->next;
                cur->next=cur->next->next;
                delete tmp;
            }
            else
            {
                cur=cur->next;
            }
        }
        head=virtualhead->next;//原来的head可能被删除了
        delete virtualhead;
        return head;
    }
};

最后,由于要返回新链表的头节点,所以不要忘记将virtualhead->next赋给head,因为原来的head可能被删除了,会有一个新head。

相关文章:

  • iOS应用手动脱壳砸壳教程
  • 代码随想录算法训练营第三十一天 | 56. 合并区间 738.单调递增的数字
  • linux下自旋锁(spin_lock)
  • 回归算法模型总结
  • unity pico开发 四 物体交互 抓取 交互层级
  • 芯麦GC1262E:电脑散热风扇驱动芯片的优质之选并可替代传统的APX9262S茂达芯片
  • OFD签章技术和情景案例
  • M系列芯片 MacOS 在 Conda 环境中安装 TensorFlow 2 和 Keras 3 完整指南
  • 【C++】stack和queue以及priority_queue的使用以及模拟实现
  • 《基于HarmonyOS NEXT API 12+,搭建新闻创作智能写作引擎》
  • 2025国家护网HVV高频面试题总结来了04(题目+回答)
  • 【大厂AI实践】美团:美团智能客服核心技术与实践
  • Spring MVC 程序开发(1)
  • QT实现计算器
  • MYSQL中使用EXPLAIN关键字分析查询的执行计划
  • 移动端国际化翻译同步解决方案-V3
  • 函数的特殊形式——递归函数
  • 注意力机制详解笔记 Attention is all I donot understand!
  • 通信TCP
  • 2025 年:SAP 咨询的关键转折点
  • 欧盟就逐步放松对叙利亚制裁达成一致
  • 新四军老战士、苏州市文联原副主席张景坤逝世
  • 西安市长安区与航天基地区政合一管理,党政一把手分任基地党工委正副书记
  • 520、521婚登预约迎高峰?上海民政:将增派力量,新人可现场办理
  • 以色列总理:以哈谈判内容包括“结束战争的框架”
  • 茅台总经理到访五粮液:面对白酒行业周期性调整,需要团结一心的合力