LeetCode删除排序链表中的重复元素的问题使用JavaScript解题|前端学算法

简介: LeetCode删除排序链表中的重复元素的问题使用JavaScript解题|前端学算法

删除排序链表中的重复元素


给定一个已排序的链表的头 head删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表


image.png


示例 1:

输入: head = [1,1,2]

输出: [1,2]


image.png


示例2:

输入: head = [1,1,2,3,3]

输出: [1,2,3]


解题思路


我们可以初始化一个节点,作为当前节点,用这个节点与下一个节点比较是否相同;如果相同,就令当前节点指向下下一个节点;如果不同就令当前节点指向下一个节点


image.png


具体步骤如下:

  • 第一步:初试话当前节点等于head
  • 第二步: 当当前节点存在且下一个节点存在则进入循环
  • 判断当前值与下一个节点的值是否相同
  • 相同使当前节点指向下下一个节点
  • 不同就让当前节点指向下一个节点
  • 第三步: 返回head
var deleteDuplicates = function(head) {
    let current = head
     while(current && current.next) {
        if(current.val == current.next.val) {
            current.next = current.next.next;
        } else {
            current = current.next;
        }
    }
    return head;
};


image.png


知识点


  • 链表和数组相似,它们都是有序的列表、都是线性结构(有且仅有一个前驱、有且仅有一个后继)。不同点在于,链表中,数据单位的名称叫做“结点”,而结点和结点的分布,在内存中可以是离散的。


image.png


关于链表的一些简单操作和基础知识大家可以看这一片文章:栈,队列和链表三者之间的关系与区别


目录
相关文章
|
2天前
|
索引
每日一题:力扣328. 奇偶链表
每日一题:力扣328. 奇偶链表
11 4
|
3天前
leetcode代码记录(移除链表元素
leetcode代码记录(移除链表元素
9 0
|
5天前
|
算法 JavaScript 前端开发
三个js算法
三个js算法
8 2
|
5天前
|
算法 JavaScript
js的两个常用算法
js的两个常用算法
5 1
|
5天前
|
JavaScript 前端开发
js数组排序的方法
js数组排序的方法
7 1
|
11天前
|
JavaScript 前端开发 算法
【JavaScript技术专栏】使用JavaScript实现常见算法
【4月更文挑战第30天】本文介绍了如何使用JavaScript实现常见算法,包括排序、搜索和图算法。首先,通过JavaScript的`sort`方法讨论了排序算法,以快速排序为例展示了自定义排序的实现。接着,探讨了二分查找这一高效的搜索算法,并提供了实现代码。最后,解释了深度优先搜索(DFS)图算法,并给出了在JavaScript中的实现。理解并运用这些算法能有效提升编程能力。
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——链表的中间结点
【每日一题】LeetCode——链表的中间结点
|
2月前
|
算法
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
|
2月前
|
存储
LeetCode刷题---817. 链表组件(哈希表)
LeetCode刷题---817. 链表组件(哈希表)

热门文章

最新文章