给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。
示例 1:
输入: 1->2->3->3->4->4->5
输出: 1->2->5
示例 2:
输入: 1->1->1->2->3
输出: 2->3
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode deleteDuplicates(ListNode head) {
if(head==null||head.next==null)
return head;
ListNode res = new ListNode(-1);
ListNode p = head;
ListNode q = head.next;
ListNode temp = res;
while (p!=null&&q!=null){
if(p.val==q.val){
//删除p后面的重复元素
while (q!=null&&p.val==q.val){
p.next = q.next;
q = q.next;
}
//删除第一个重复元素
temp.next = q;
p = q;
if(q!=null)
q = q.next;
}else {//如果没遇到重复元素,则添加该节点
temp.next = p;
temp = temp.next;
p = q;
q = p.next;
}
}
return res.next;
}
}