AcWing 29. 删除链表中重复的节点
原题链接
中等
作者:
虎头虎脑
,
2022-04-05 21:37:03
,
所有人可见
,
阅读 187
C++ 代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* deleteDuplication(ListNode* head) {
//涉及到可能删除头结点的,可以定义一个虚拟头结点
auto dummy = new ListNode(-1);
dummy->next = head; //虚拟节点的next指向head,这样删除head更加方便
auto p = dummy;
while(p->next) //p-next == head;
{
auto q = p->next;
while(q && p->next->val == q->val) q = q->next; //判断是否是重复节点
//通过上面的while,q指向的就是非重复元素
if(p->next->next == q) p = p->next; //如果话p->next->next == q,说明后一个节点只有一个,p向后移动一位
else p->next = q; //是重复节点的话,将p的next指向下一个非重复元素
}
return dummy->next; //返回数据
}
};