【百日算法计划】:每日一题,见证成长(007)

题目

移除链表元素

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

示例:

输入:head = [1,2,6,3,4,5,6], val = 6

输出:[1,2,3,4,5]

思路1

不引入虚拟头节点 (需要对头节点特殊处理)

java 复制代码
 public ListNode removeElements1(ListNode head, int val) {
    if (head == null) return null;
    ListNode prev = head;
    while (prev.next != null){
        if (prev.next.val == val){
            prev.next = prev.next.next; //注意这个时候prev不需要后移
        } else {
            prev = prev.next;
        }
    }
    //因为是从prev.next开始判断的,所以第一个节点没有判断到,需要特殊处理
    if (head.val == val){
        head = head.next;
    }
    return head;
}

思路2

引入虚拟头节点

java 复制代码
public ListNode removeElements2(ListNode head, int val) {
   ListNode host = new ListNode();//创建一个虚拟头节点
   host.next = head;
   ListNode pre = host;
   while (pre.next != null){
       if (pre.next.val == val){
           pre.next = pre.next.next;
       } else {
           pre = pre.next;
       }
   }
   return host.next;
}

思路3

引入一个新的结果链表,利用tail指针尾插

java 复制代码
public ListNode removeElements3(ListNode head, int val) {
    ListNode host = new ListNode();//创建一个虚拟头节点
    ListNode tail = host; //tail指针
    ListNode p = head;
    while (p != null){
        ListNode temp = p.next;
        if (p.val != val){
            p.next = null;
            tail.next = p;
            tail = p;
        }
        p = temp.next;
    }
    return host.next;
}
相关推荐
GGBondlctrl9 分钟前
【leetcode】递归,回溯思想 + 巧妙解法-解决“N皇后”,以及“解数独”题目
算法·leetcode·n皇后·有效的数独·解数独·映射思想·数学思想
武子康21 分钟前
大数据-276 Spark MLib - 基础介绍 机器学习算法 Bagging和Boosting区别 GBDT梯度提升树
大数据·人工智能·算法·机器学习·语言模型·spark-ml·boosting
武子康24 分钟前
大数据-277 Spark MLib - 基础介绍 机器学习算法 Gradient Boosting GBDT算法原理 高效实现
大数据·人工智能·算法·机器学习·ai·spark-ml·boosting
Andrew_Xzw1 小时前
数据结构与算法(快速基础C++版)
开发语言·数据结构·c++·python·深度学习·算法
超的小宝贝2 小时前
数据结构算法(C语言)
c语言·数据结构·算法
木子.李3478 小时前
排序算法总结(C++)
c++·算法·排序算法
闪电麦坤959 小时前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
Gyoku Mint10 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦10 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法