82. 删除排序链表中的重复元素 II
Posted 易小顺
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了82. 删除排序链表中的重复元素 II相关的知识,希望对你有一定的参考价值。
算法记录
LeetCode 题目:
存在一个按升序排列的链表,给你这个链表的头节点 head
,请你删除链表中所有存在数字重复情况的节点,只保留原始链表中 没有重复出现 的数字。
返回同样按升序排列的结果链表。
说明
一、题目
输入:head = [1,2,3,3,4,4,5]
输出:[1,2,5]
二、分析
- 删除重复的元素,因为是排序好的,也就是重复的都会挨在一起,先找到邻接的节点相等。
- 然后找到第一个的头结点和该元素的最后一个,直接将此头结点指向下一个即可完成重复元素的删除。
- 不能直接从第一步开始就就直接删除,因为不知道后面还有没有此元素的重复元素。
/**
* 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 || head.next == null) return head;
ListNode hair = new ListNode(-1, head);
ListNode pre = hair, cur = pre.next;
while(cur != null && cur.next != null) {
if(cur.val != cur.next.val) {
pre = pre.next;
cur = cur.next;
} else {
while(cur != null && cur.next != null && cur.val == cur.next.val) cur = cur.next;
pre.next = cur.next;
cur = cur.next;
}
}
return hair.next;
}
}
总结
熟悉链表的遍历和节点删除。
以上是关于82. 删除排序链表中的重复元素 II的主要内容,如果未能解决你的问题,请参考以下文章