题目描述

输入样例
[21,-15,-15,7,15]
输出样例
[21,-15,7]
分析
如果不允许使用临时的缓存(即不能使用额外的存储空间),那需要两个指针,空间复杂度O(1) 当第一个指针指向某个元素时,第二个指针把该元素后面节点绝对值与它相同的元素删除,时间复杂度O(n2n^2n2).
C++ 代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
void deleteDuplication(ListNode* head) {
ListNode *p,*q,*cur=head; //设计3个指针,p,q,cur,cur最初指向链表头结点。
while(cur)
{
p=cur,q=cur->next; //初始化:p指向当前点,q用于查找当前点后所有的点
while(q)
{
if(q->val==cur->val || q->val==-cur->val) //当元素的绝对值与当前节点cur的值相同时,就删掉该节点
{
ListNode *t=(ListNode*)malloc(sizeof(ListNode));
t=q;
p->next=q->next;
q=p->next;
delete(t);
}
else{
p=q,q=q->next;
}
}
cur=cur->next;
}
}
};
本文介绍了一种在链表中去除绝对值重复元素的算法,采用三个指针进行操作,不使用额外空间,实现了空间复杂度O(1)。通过遍历链表,利用两个指针查找并移除当前节点后所有绝对值与之相同的节点。
466

被折叠的 条评论
为什么被折叠?



