题目描述
在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5

来源:https://www.nowcoder.com/practice/fc533c45b73a41b0b44ccba763f866ef?tpId=13&tqId=11209&tPage=3&rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

思路:
与链表的其他题目类似,为了防止删除头结点的极端情况发生,先创建空结点dummy,使dummy指向传入的head结点。
然后创建cur的指针,指向链表的头部(即dummy)。
接着对cur指针迭代,因为要对比cur(cur最初始的定义指向空结点)指针的下一个结点与下下一个结点的值是否相等,为了防止产生空指针异常,故退出迭代的条件为:cur.next != null && cur.next.next != null。
在迭代过程中,如果cur.next.val == cur.next.next.val说明此时有重复元素,此时创建一个临时指针temp,指向cur的下一个节点,即temp指向的第一个重复元素所在的位置。通过while循环去重,去重后,temp指向的是重复元素中的最后一个位置。最后cur.next = temp.next就实现了消除重复元素。
当然,如果为发现重复元素,则直接向后迭代即可。
迭代完成后,返回dummy的next。

/*
public class ListNode {
int val;
ListNode next = null;

ListNode(int val) {
this.val = val;
}
}
*/
public class Solution {
public ListNode deleteDuplication(ListNode pHead){
if(pHead==null){
return null;
}
ListNode head0 = new ListNode(-1);
head0.next = pHead;
ListNode pre = head0;//用于保存前驱结点
while(pre.next!=null&&pre.next.next!=null){
if(pre.next.val==pre.next.next.val){
ListNode temp = pre.next;
//去重,让temp指向最后一个重复结点
while(temp!=null&&temp.next!=null&&temp.val==temp.next.val){
temp = temp.next;
}
//前驱结点的后继指向最后一个重复结点的后继
pre.next = temp.next;
}else{
//没有重复结点就往下走
pre = pre.next;
}

}
return head0.next;

}
}