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


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


目录
相关文章
|
1月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
25天前
|
前端开发
前端 CSS 经典:元素倒影
前端 CSS 经典:元素倒影
10 1
|
1月前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
1月前
|
存储 SQL 算法
LeetCode 题目 86:分隔链表
LeetCode 题目 86:分隔链表
|
25天前
|
前端开发
前端 CSS 经典:保持元素宽高比
前端 CSS 经典:保持元素宽高比
20 0
|
25天前
2670.找出不同元素数目差数组-力扣(LeetCode)
2670.找出不同元素数目差数组-力扣(LeetCode)
9 0
|
29天前
|
存储 算法 Java
力扣经典150题第四十五题:存在重复元素 II
力扣经典150题第四十五题:存在重复元素 II
13 0
|
1月前
|
索引
leetcode题解:27.移除元素
leetcode题解:27.移除元素
21 0
|
1月前
|
算法
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
|
1月前
|
存储 SQL 算法
LeetCode 83题:删除排序链表中的重复元素【面试】
LeetCode 83题:删除排序链表中的重复元素【面试】