题目描述

思路一
我们使用vector<int>的数据结构来存储链表节点,如果当前节点的元素和前一个节点的元素相同,就将该vector[i]和vector[i-1]标记为-101,再次遍历时,移动链表节点cur的同时对vector的遍历指针i做自增操作,如果是标记为,则进行改变pre->next
思路二
当下一个节点的值等于下下一个节点的值时,我们跳过下一个节点,当前节点的next指针直接指向下下一个节点,但是这也导致一个问题:比如1,2,2,,2,3,4,5这样的序列,我们需要去除2,但是只能删除前面的'2',无法删除最后的'2',如何解决这一问题呢?我们可以通过一个变量X记录重复值,我们每次判断cudr->next的值是否等于X(前提是cur存在),入股cur->next存在且cur->next->val==X,那么我们令cur->next=cur->next->next
如下(无法删除最后一个重复元素的)代码:
class Solution {
public:
ListNode* deleteDuplicates(ListNode* head) {
ListNode* dummyHead = new ListNode(-101);
dummyHead->next = head;
ListNode* cur = dummyHead;
while (cur->next && cur->next->next) {
if (cur->next->val == cur->next->next->val) {
while (c

这篇博客探讨了如何删除排序链表中的重复元素。思路一是利用vector数据结构,当遇到相同节点时标记为-101,然后在遍历时移除。思路二是通过记录重复值X,当cur->next的值等于X时,跳过下一个节点。但这种方法无法删除最后一个重复元素。正确做法是判断cur->next和cur->next->next,根据它们的值来调整链表结构。
最低0.47元/天 解锁文章
329

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



