算法3(力扣83)-删除链表中的重复元素

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

2、实现( 因为已排序,所以元素若重复,必然在其下一位)(这里为在vscode上看见实现效果,直接使用具名函数)

(1)定义链表结构

(2)定义头结点

(3)分两种情况

1)链表为空链表(直接返回)
2)链表非空(相等删除,不等指针下移一位)

(4)调用

3、完整代码

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>删除链表中的重复元素</title>
</head>
<body>
    <p>
        给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。
    </p>
    <p>
        输入:head = [1,1,2]
        输出:[1,2]
    </p>
    <p>
        输入:head = [1,1,2,3,3]
        输出:[1,2,3]
    </p>
</body>
<script>
    class ListNode{
            constructor(val, next){
            this.val = val
            this.next = next
        } 
    }
    let head = new ListNode(1)
        head.next = new ListNode(1)
        head.next.next = new ListNode(2)

    deleteDuplicates(head)
    function deleteDuplicates(head) {
            // 头结点为空,直接返回
            if (!head) return head;
            // 头结点非空时,让当前指针指向head,在循环中判断,当循环中一个节点的值和该节点下一节点的值相等时,删除;否则,指针移向下一位
            let cur = head
            while (cur.next) {
                if (cur.val === cur.next.val) {
                    cur.next = cur.next.next
                } else {
                    cur = cur.next
                }
            }
            console.log(head);
            
            return head

        }    




</script>
</html>

4、力扣使用代码

javascript 复制代码
    var deleteDuplicates = function (head) {
        // 头结点为空,直接返回
        if(!head) return head;
        // 头结点非空时,让当前指针指向head,在循环中判断,当循环中一个节点的值和该节点下一节点的值相等时,删除;否则,指针移向下一位
        let cur = head
        while (cur.next) {
            if (cur.val===cur.next.val) {
                cur.next=cur.next.next
            }else{
                cur = cur.next
            }
        }
        return head
        
    }
相关推荐
仰泳的熊猫12 分钟前
题目2580:蓝桥杯2020年第十一届省赛真题-分类计数
数据结构·c++·算法·蓝桥杯
qyzm12 分钟前
牛客周赛 Round 136
数据结构·python·算法
Magic--13 分钟前
从入门到精通:快速排序的核心原理、实现与优化
数据结构·算法·排序算法
weixin_6495556713 分钟前
C语言程序设计第四版(何钦铭、颜晖)第十章函数与程序结构之统计完全平方数
c语言·数据结构·算法
Magic--20 分钟前
选择排序:原理、实现与优化
数据结构·算法·排序算法
cui_ruicheng28 分钟前
C++ 数据结构进阶:unordered_map 与 unordered_set源码分析与实现
数据结构·c++·算法·哈希算法
ccLianLian39 分钟前
数论·快速幂和逆元
数据结构·算法
牢姐与蒯41 分钟前
vector的实现
数据结构
_饭团1 小时前
C 语言数据存储全解析:原反补码、大小端与 IEEE 754 浮点数
c语言·数据结构·算法·leetcode·面试·蓝桥杯·学习方法
j_xxx404_1 小时前
力扣--分治(归并排序)算法题II:计算右侧小于当前元素的个数,翻转对(无痛通关困难题)
开发语言·数据结构·c++·算法·leetcode