83. 删除排序链表中的重复元素

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

示例 1:

img

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

示例 2:

img

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

提示:

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

题解:

双指针

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public ListNode deleteDuplicates(ListNode head) {
/*
* 双指针法:
* 因为是排序链表,所以重复元素肯定相邻
* 使用两个并列的指针对链表进行遍历,
* 逐一比较
*
* */

if (head == null || head.next == null){
return head;
}


ListNode pre = head;
ListNode cur = head.next;


while (cur != null){
if (pre.val == cur.val){
pre.next = cur.next;
cur = cur.next;
}else {
pre = cur;
cur = cur.next;
}
}

return head;

}
  • 时间复杂度:O(N)
  • 空间复杂度:O(1)