02.01、移除重复节点

02.01、[简单] 移除重复节点

1、题目描述

编写代码,移除未排序链表中的重复节点。保留最开始出现的节点。

2、解题思路

为了实现这一目标,我们可以使用一个哈希表(或集合)来记录已经遇到的节点值,逐步遍历链表并删除重复的节点。

具体步骤如下:

  1. 从链表的第一个节点开始遍历,创建一个哈希表来记录已经遇到的节点值。
  2. 如果遇到的节点值不在哈希表中,则将该值添加到哈希表中,并继续遍历。
  3. 如果遇到的节点值已经存在于哈希表中,说明该节点是重复的节点,将其从链表中删除。
  4. 最终返回处理后的链表。

3、代码实现与详细注释

复制代码
class Solution {
public:
    ListNode* removeDuplicateNodes(ListNode* head) {
        // 边界条件:如果链表为空或只有一个节点,直接返回头节点
        if (head == nullptr || head->next == nullptr) {
            return head;
        }

        // 使用一个哈希表记录已经遇到的节点值
        unordered_map<int, int> hash;
        ListNode* cur = head;  // 从链表的第一个节点开始遍历
        hash[cur->val]++;      // 记录第一个节点的值

        // 开始遍历链表的后续节点
        while (cur->next) {
            ListNode* next = cur->next;  // 记录当前节点的下一个节点

            // 如果下一个节点的值已经在哈希表中出现过,说明是重复节点
            if (hash.count(next->val)) {
                // 删除重复节点:将当前节点的 next 指向下下个节点
                cur->next = next->next;
            } else {
                // 如果下一个节点的值没有出现过,则记录该值
                hash[next->val]++;
                // 移动当前指针到下一个节点
                cur = next;
            }
        }

        // 返回去重后的链表头节点
        return head;
    }
};

4、时间与空间复杂度分析

  • 时间复杂度: O(n),其中 n 为链表的长度。我们只需要遍历链表一次,同时每个节点的值存储或查找在哈希表中的时间是常数级别。
  • 空间复杂度: O(n),因为需要使用哈希表来存储已经访问过的节点值。

这种方法效率较高,适合链表长度较大且包含重复节点的情况。

相关推荐
byte轻骑兵7 分钟前
【C++ 类和数据抽象】static 类成员
开发语言·c++
努力学习的小廉14 分钟前
【C++】 —— 笔试刷题day_24
开发语言·c++
明月清了个风16 分钟前
数据结构与算法学习笔记(Acwing提高课)----动态规划·数字三角形
笔记·学习·算法·动态规划
刃神太酷啦16 分钟前
堆和二叉树--数据结构初阶(3)(C/C++)
c语言·数据结构·c++·算法·leetcode·深度优先·宽度优先
●VON20 分钟前
杭电oj(1087、1203、1003)题解
算法·leetcode·职场和发展
用户jjbjjbk36 分钟前
QT多线程以及事件循环
c++·qt
良木林37 分钟前
240424 leetcode exercises II
c语言·数据结构·算法·leetcode
阳光_你好40 分钟前
医学图像(DICOM数据)读取及显示(横断面、冠状面、矢状面、3D显示)为什么用ITK+VTK,单独用ITK或者VTK能实一样功能吗?
c++
啊阿狸不会拉杆1 小时前
数据结构-排序
java·c语言·数据结构·c++·python·算法·排序算法
姜行运1 小时前
数据结构【树和二叉树】
android·数据结构·算法·c#