- 题目:
给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2
输出: 1->2
示例 2:
输入: 1->1->2->3->3
输出: 1->2->3
- 解题思路
方法一:
由于是有序链表,利用两个工作指针指向相邻的元素,并不断比较两个节点中元素的值,若相同则删除,否则继续比较。
代码实现:
ListNode* deleteDuplicates(ListNode* head) {
if(head == nullptr)
return head;
ListNode *p = head, *q = head->next;
while(q != nullptr)
{
if(p->val == q->val)
{
p->next = q->next;
q = p->next;
}
else
{
p = p->next;
q = q->next;
}
}
return head;
}
此方法在在LeetCode上提交花费16ms,时间较长,接着我又注意到每次都要更新p,q指针,是不是可以直接找到链表直接指向的下一节点。
方法二:
q指针直接指向指向下一个不同的节点,再删除.
代码实现:
ListNode* deleteDuplicates(ListNode* head) {
if(head == nullptr)
return head;
ListNode *p = head, *q = head->next;
while(q != nullptr)
{
while(q!= nullptr && q->val == p->val) //找到第一个不同的节点
{
q = q->next;
}
if(q == nullptr) //q为空,值p之后无相同节点,直接另p指向nullptr即可
{
p->next = nullptr;
break;
}
p->next = q;
p = q;
q = q->next;
}
return head;
}
此方法在在LeetCode上提交花费8ms
方法三:递归
ListNode* deleteDuplicates(ListNode* head) {
if(head == nullptr || head->next == nullptr) //递归出口
return head;
head->next = deleteDuplicates(head->next);
return head->val == head->next->val? head->next:head; //判断第一二个节点值是否相同
}