删除排序链表中的重复元素 II
给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。
/**
* 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 dummy= new ListNode(0,head);
ListNode pre=dummy;
ListNode curr=pre.next;
//循环结束条件
while(curr!=null && curr.next!=null){
if(curr.val==curr.next.val){
int x =curr.val;
//如果重复,则让curr跳出去
while(curr!=null && curr.val==x){
curr=curr.next;
}
//无重复之后,再把pre和curr重新链接
pre.next=curr;
//如果不重复,就往下走
}else{
pre=curr;
curr=curr.next;
}
}
return dummy.next;
}
}