❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)

简介: ❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)

题目

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

示例 1:

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

示例 2:

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

提示:

  • 链表中节点数目在范围 [0, 300]
  • -100 <= Node.val <= 100
  • 题目数据保证链表已经按升序 排列

Related Topics

链表

👍 1115

👎 0

思路

  • 快慢指针法
  • 其实这个和数组那个去重思路一模一样

解答

//给定一个已排序的链表的头
// head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 
//
// 
//
// 示例 1: 
// 
// 
//输入:head = [1,1,2]
//输出:[1,2]
// 
//
// 示例 2: 
// 
// 
//输入:head = [1,1,2,3,3]
//输出:[1,2,3]
// 
//
// 
//
// 提示: 
//
// 
// 链表中节点数目在范围 [0, 300] 内 
// -100 <= Node.val <= 100 
// 题目数据保证链表已经按升序 排列 
// 
//
// Related Topics 链表 👍 1115 👎 0
//leetcode submit region begin(Prohibit modification and deletion)
/**
 * 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 dummy = new ListNode(); // 创建一个哑节点作为新链表的头
        dummy.next = head;
        ListNode slow = dummy, fast = head;
        while (fast != null) {
            if (fast.next == null || fast.val != fast.next.val) {
                // 当fast指向的元素不重复时,将其连接到slow之后,并将slow向前移动
                slow.next = fast;
                slow = slow.next;
            }
            fast = fast.next; // fast继续向前移动
        }
        // 将slow之后的元素删除,确保链表在此之后没有其他的元素
        slow.next = null;
        return dummy.next; // 返回新链表的头(跳过哑节点)
    }
}
//leetcode submit region end(Prohibit modification and deletion)


目录
相关文章
|
1天前
|
算法
❤️算法笔记❤️-(每日一刷-26、删除有序数组的重复项)
❤️算法笔记❤️-(每日一刷-26、删除有序数组的重复项)
4 0
|
1天前
|
算法
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
8 0
|
1天前
|
存储 算法
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
5 0
|
4月前
|
存储 算法
数据结构和算法学习记录——删除有序数组中的重复项、合并两个有序数组
数据结构和算法学习记录——删除有序数组中的重复项、合并两个有序数组
22 0
数据结构和算法学习记录——删除有序数组中的重复项、合并两个有序数组
|
4月前
|
数据采集 算法 数据挖掘
LeetCode 题目 80:删除排序数组中的重复项 II【算法面试高频题】
LeetCode 题目 80:删除排序数组中的重复项 II【算法面试高频题】
|
5月前
【一刷《剑指Offer》】面试题 17:合并两个排序的链表
【一刷《剑指Offer》】面试题 17:合并两个排序的链表
|
Cloud Native
【刷题日记】80. 删除有序数组中的重复项 II
本次刷题日记的第 73 篇,力扣题为:80. 删除有序数组中的重复项 II,中等
|
Cloud Native
【刷题日记】26. 删除有序数组中的重复项
本次刷题日记的第 55 篇,力扣题为:26. 删除有序数组中的重复项,简单
|
5月前
|
算法
刷题专栏(四):删除排序链表中的重复元素
刷题专栏(四):删除排序链表中的重复元素
50 0
LeetCode150道面试经典题-删除有序数组中的重复项(简单)
一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 ​
41 0