前端算法-链表移除元素

简介: 前端算法-链表移除元素

题目

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

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

思路一

这里我们先使用递归进行实现,首先我们进入函数之后先判断当前head是否为null,如果是则直接返回null,如果不为空则往下执行,接下来我们声明一个res变量,用于存储递归调用自身removeElements函数的返回值,我们调用removeElements函数时,将当前的head的next参数和形参val传递进去,然后使用if判断head的val属性是否等于当前的val形参,如果两者相等,则直接将当前的res变量值返回出去即可,如果不相等,则把res变量值赋值给head的next属性,最后在将head返回出去即可

/**
 * @param {ListNode} head
 * @param {number} val
 * @return {ListNode}
 */
var removeElements = function(head, val) {
    if (head === null) {
        return null
    }
    let res = removeElements(head.next, val)
    if(head.val === val){
        return  res;
    }else{
        head.next = res;
        return head;
    }
};

思路二

我们这里先考虑边界值,如果传入的节点为空,就返回空,然后生成一个新的头节点,然后让头节点指向原来链表的第一个节点,在声明一个指针,指向头节点,其next节点为原来链表的第一个节点,如果链表不为空,则循环遍历,如果p指针指向的下一个元素等于val,那么就移除此元素,否则p指针后移,最后返回头节点后面的链表

/**
 * @param {ListNode} head
 * @param {number} val
 * @return {ListNode}
 */
var removeElements = function(head, val) {
 if (head === null) {
        return null
    }
    var firstNode = new ListNode();
    firstNode.next = head;
    var p = firstNode;
    while(p.next!=null){
      p.next.val == val? p.next = p.next.next: p = p.next;
    }
    return firstNode.next;
};


相关文章
|
1月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
35 1
|
1月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
41 3
|
1月前
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
33 4
|
2月前
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
43 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
2月前
|
前端开发
前端基础(十四)_隐藏元素的方法
本文介绍了几种在前端开发中隐藏元素的方法,包括使用`display:none`、`visibility:hidden`、`opacity:0`等CSS属性,并提供了相应的示例代码。此外,还提到了其他隐藏元素的技巧,如通过设置元素位置、使用`overflow`属性和`filter`属性以及`rgba`颜色值来实现元素的隐藏。
66 1
前端基础(十四)_隐藏元素的方法
01_移除链表元素
01_移除链表元素
|
1月前
|
移动开发 算法 前端开发
前端常用算法全解:特征梳理、复杂度比较、分类解读与示例展示
前端常用算法全解:特征梳理、复杂度比较、分类解读与示例展示
22 0
|
2月前
|
前端开发 JavaScript
前端基础(七)_DOM元素获取(getElementById、getElementsByTagName、getElementsByClassName、querySelector等)
本文介绍了如何在前端通过不同的方法获取DOM元素,包括getElementById、getElementsByTagName、getElementsByClassName、querySelector和querySelectorAll。
94 3
|
2月前
|
算法 前端开发 机器人
一文了解分而治之和动态规则算法在前端中的应用
该文章详细介绍了分而治之策略和动态规划算法在前端开发中的应用,并通过具体的例子和LeetCode题目解析来说明这两种算法的特点及使用场景。
一文了解分而治之和动态规则算法在前端中的应用
|
1月前
【LeetCode 06】203.移除链表元素
【LeetCode 06】203.移除链表元素
30 0
下一篇
无影云桌面