删除排序链表中的重复元素 II
中等
给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。
示例 1:
输入:head = [1,2,3,3,4,4,5]
输出:[1,2,5]
示例 2:
输入:head = [1,1,1,2,3]
输出:[2,3]
题解
创建一个哑节点,用于操作链表和返回。
先判断两个节点不为空,可以进行比较,如果两个节点值相等,用一个变量x记录该节点值val,循环遍历,直至cur节点的val值不与之前记录的val值相等,通过遍历就把相同值节点删除了,如果一开始就不想等,就后移一位,继续与移动后的下一位节点比较。
class Solution {
public ListNode deleteDuplicates(ListNode head) {
if (head == null) {
return head;
}
ListNode dummy = new ListNode(0, head);
ListNode cur = dummy;
while (cur.next != null && cur.next.next != null) {
if (cur.next.val == cur.next.next.val) {
int x = cur.next.val;
while (cur.next != null && cur.next.val == x) {
cur.next = cur.next.next;
}
} else {
cur = cur.next;
}
}
return dummy.next;
}
}