力扣:82. 删除排序链表中的重复元素 II(Java)

目录

题目描述:

给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。

输入:

bash 复制代码
head = [1,2,3,3,4,4,5]

输出:

bash 复制代码
[1,2,5]

代码实现:

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 * int val;
 * ListNode next;
 * ListNode() {}
 * ListNode(int val) { this.val = val; }
 * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        if (head == null) {// 链表为空的情况
            return null;
        }
        // 创建一个哑结点,指向链表的头节点:方便后续删除操作
        ListNode temp = new ListNode(0, head);
        ListNode cur = temp;// 创建遍历链表使用的指针cur
        while (cur.next != null && cur.next.next != null) {// 保证连续两个后继都不为空
            if (cur.next.val == cur.next.next.val) {// 当出现重复元素时
                int x = cur.next.val;// 记录重复元素的值val
                while (cur.next != null && cur.next.val == x) {
                    // 从当前cur指向的结点开始,循环删除所有val为x的节点
                    cur.next = cur.next.next;// cur指向其后继的后继
                }
            } else {
                // 未出现重复元素时,正常往后遍历链表
                cur = cur.next;
            }
        }
        return temp.next;// 返回哑节点的后继
    }
}
相关推荐
字节全栈_mMD31 分钟前
Flink Connector 写入 Iceberg 流程源码解析_confluent icebergsinkconnector
java·大数据·flink
小园子的小菜1 小时前
RocketMQ中的NameServer主要数据结构
java·中间件·rocketmq·java-rocketmq
平凡君1 小时前
缓存的今生今世
java·spring·缓存
纠结哥_Shrek2 小时前
Java 有很多常用的库
java·开发语言
爱是小小的癌2 小时前
Java-数据结构-优先级队列(堆)
java·前端·数据结构
sjsjs112 小时前
【数据结构-字典树】力扣14. 最长公共前缀
数据结构·leetcode
天乐敲代码2 小时前
JAVASE入门十五脚-网络TCP,UDP,,Lambda
java
2501_903238653 小时前
自定义登录页面的Spring Security实践
java·后端·spring·个人开发
JNU freshman4 小时前
力扣第435场周赛讲解
算法·leetcode·蓝桥杯
飞翔的佩奇4 小时前
Java项目: 基于SpringBoot+mybatis+maven+mysql实现的图书管理系统(含源码+数据库+答辩PPT+毕业论文)
java·数据库·spring boot·mysql·spring·毕业设计·图书管理