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

题目

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

示例1:

示例1

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

示例2:

示例2

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

提示:

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

解法

解法一:

Java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public ListNode deleteDuplicates(ListNode head) {
if (Objects.isNull(head) || Objects.isNull(head.next)) {
return head;
}

ListNode dummyNode = new ListNode(-101);
dummyNode.next = head;
ListNode cur = dummyNode;
while (!Objects.isNull(cur.next)) {
if (cur.val == cur.next.val) {
cur.next = cur.next.next;
continue;
}
cur = cur.next;
}
return dummyNode.next;
}
0%