leetcode 83. 删除排序链表中的重复元素
题意
给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2
输出: 1->2
示例 2:
输入: 1->1->2->3->3
输出: 1->2->3
解题思路
用 p
记录当前节点。用 iter
作为迭代器,寻找下一个与 p
不相等的节点,并把找到的节点赋值给 p.next
。
代码
/**
* 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 p = head;
while (p != null && p.next != null)
{
ListNode iter = p;
while (iter.next != null)
{
iter = iter.next;
if (p.val != iter.val)
{
break;
}
}
if (p.val != iter.val)
{
p.next = iter;
p = p.next;
}
else
{
p.next = null;
}
}
return head;
}
}