给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2
输出: 1->2
示例 2:
输入: 1->1->2->3->3
输出: 1->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) {
ListNode a = head;
while(a != null && a.next != null){
if(a.val == a.next.val){
a.next = a.next.next;
}
else{
a = a.next;
}
}
return head;
}
}