LeetCode 82 Remove Duplicates from Sorted List II(从已排序链表中移除重复元素)(Linked List)(*)

简介: 版权声明:转载请联系本人,感谢配合!本站地址:http://blog.csdn.net/nomasp https://blog.csdn.net/NoMasp/article/details/52186216 翻译给定一个已排序链表,删除所有的重复节点,只保留原始链表中独特的数字。
版权声明:转载请联系本人,感谢配合!本站地址:http://blog.csdn.net/nomasp https://blog.csdn.net/NoMasp/article/details/52186216

翻译

给定一个已排序链表,删除所有的重复节点,只保留原始链表中独特的数字。

例如,
给定 1->2->3->3->4->4->5, 返回 1->2->5.
给定 1->1->1->2->3, 返回 2->3.

原文

Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.

For example,
Given 1->2->3->3->4->4->5, return 1->2->5.
Given 1->1->1->2->3, return 2->3.

分析

这类问题一般都要特地构造一个头部,比如说

1 -> 1 -> 2 -> 3 -> NULL

这个时候如果把1删掉了,那么head放在哪?相反,如果是

x -> 1 -> 1 -> 3 -> NULL

这样的话,把1都删掉了,x还可以充当头部,不管取什么值都可以,反正最后返回的肯定是

return x->next;

这里写图片描述

不知道我排版得有没有对齐,应该不影响阅读吧。反正核心思想是,如果p所在的位置和下一个位置的值相同,就一直往后走。而且走到最后一个3的时候,记得还要再走一步才能到4。

那么c和p之间如何跨越这么大的鸿沟呢,最后一句c->next = p,就将它们有紧密的联合起来了,绝对是一对好CP,这也是我给它们这样命名的原因。

之所以要设定这么一个CP,就是因为在这里不像上一题一样,删除重复节点的时候是都要删掉,不会留下一个。换句话说,如果是每次只删一个,最后肯定会有一个留下没有被删除,因为它前后重复都删掉了,剩下继续比较的都是不重复的。因此应该加一个标记,用于最后一次性删除。这里的删除也就是跳过一个节点。

LeetCode 83 Remove Duplicates from Sorted List(从已排序链表中移除重复元素)(Linked List)

代码

C Plus Plus

ListNode *deleteDuplicates(ListNode *head) {
  if (head == NULL || head->next == NULL) return head;
  ListNode *newHead = new ListNode(0);
  newHead->next = head;

  ListNode *c = newHead, *p = head;
  while (p != NULL && p->next != NULL) {
    if (p->val != p->next->val) {
      c = c->next;
      p = p->next;
    } else {
      while (p->next != NULL && p->val == p->next->val) {
        p = p->next;
      }
      p = p->next;
      c->next = p;
    }
  }
  return newHead->next;
}

做一个小幅修改,看上去更加科学一点。

updated at 2016/08/14
ListNode* deleteDuplicates(ListNode *head) {
  if (!head || !head->next) return head;
  ListNode *newHead = new ListNode(0);
  newHead->next = head;
  ListNode *c = newHead, *p = c->next;

  while (c->next && c->next->next) {
    if (c->next->val == c->next->next->val) {
      p = p->next;
      while (p->next && p->val == p->next->val) {
        p = p->next;
      }
      c->next = p->next;
    } else {
      c = c->next;
      p = p->next;
    }
  }
  return newHead->next;
}

Java

updated at 2016/09/23
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
     public ListNode deleteDuplicates(ListNode head) {
        if (head == null || head.next == null) return head;
        ListNode newHead = new ListNode(0);
        newHead.next = head;
        ListNode c = newHead, p = c.next;

        while (c.next != null && c.next.next != null) {
            if (c.next.val == c.next.next.val) {
                p = p.next;   // 标记要跳过的节点
                while (p.next != null && p.val == p.next.val) {
                    p = p.next;  // 继续循环标记要删除的节点
                }
                c.next = p.next;
            } else {
                c = c.next;
                p = p.next;
            }
        }
        return newHead.next;
    }
}
目录
相关文章
|
1月前
【LeetCode-每日一题】 删除排序数组中的重复项
【LeetCode-每日一题】 删除排序数组中的重复项
19 4
|
1月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
26 3
|
3月前
|
存储 算法
LeetCode第83题删除排序链表中的重复元素
文章介绍了LeetCode第83题"删除排序链表中的重复元素"的解法,使用双指针技术在原链表上原地删除重复元素,提供了一种时间和空间效率都较高的解决方案。
LeetCode第83题删除排序链表中的重复元素
|
3月前
|
存储 NoSQL 算法
Redis6入门到实战------ 三、常用五大数据类型(列表(List)、集合(Set)、哈希(Hash)、Zset(sorted set))
这是关于Redis 6入门到实战的文章,具体内容涉及Redis的五大数据类型:列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset(sorted set))。文章详细介绍了这些数据类型的特点、常用命令以及它们背后的数据结构。如果您有任何关于Redis的具体问题或需要进一步的帮助,请随时告诉我。
|
3月前
|
算法 索引
LeetCode第34题在排序数组中查找元素的第一个和最后一个位置
这篇文章介绍了LeetCode第34题"在排序数组中查找元素的第一个和最后一个位置"的解题方法,通过使用双指针法从数组两端向中间同时查找目标值,有效地找到了目标值的首次和最后一次出现的索引位置。
LeetCode第34题在排序数组中查找元素的第一个和最后一个位置
|
3月前
|
索引
【Qt 学习笔记】Qt常用控件 | 多元素控件 | List Widget的说明及介绍
【Qt 学习笔记】Qt常用控件 | 多元素控件 | List Widget的说明及介绍
361 3
|
3月前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
44 0
|
3月前
|
算法 索引 Python
【Leetcode刷题Python】34. 在排序数组中查找元素的第一个和最后一个位置(二分查找)
解决LeetCode "在排序数组中查找元素的第一个和最后一个位置" 问题的方法。第一种方法是使用两次二分查找,首先找到目标值的最左边界,然后找到最右边界。第二种方法是利用Python的list.index()方法,先正序找到起始位置,再逆序找到结束位置,并给出了两种方法的Python实现代码。
61 0
|
4月前
|
存储 C++
C++的list-map链表与映射表
```markdown C++ 中的`list`和`map`提供链表和映射表功能。`list`是双向链表,支持头尾插入删除(`push_front/push_back/pop_front/pop_back`),迭代器遍历及任意位置插入删除。`map`是键值对集合,自动按键排序,支持直接通过键来添加、修改和删除元素。两者均能使用范围for循环遍历,`map`的`count`函数用于统计键值出现次数。 ```
|
5月前
力扣随机一题 哈希表 排序 数组
力扣随机一题 哈希表 排序 数组
32 1