您的位置:首页 > 其它

Remove Duplicates from Sorted List II

2014-07-07 08:19 337 查看
/**
* Definition for singly-linked list.
* public class ListNode {
*     int val;
*     ListNode next;
*     ListNode(int x) {
*         val = x;
*         next = null;
*     }
* }
*/
public class Solution {
public ListNode deleteDuplicates(ListNode head) {
if(head == null) {
return head;
}
ListNode dummy = new ListNode(0);
dummy.next = head;
ListNode prevPrev = dummy, prev = head, curr = head.next;
for( ; curr != null; curr = curr.next) {
if(curr.val != prev.val) {
if(prev.next == curr) {
prevPrev = prev;
} else {
prevPrev.next = curr;
}
prev = curr;
}
}
if(prev.next != null) {
prevPrev.next = null;
}
return dummy.next;
}
}


Time: O(n)

Space: O(1)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  LeetCode Linked List