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),因为需要使用哈希表来存储已经访问过的节点值。

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

相关推荐
小江村儿的文杰19 分钟前
理解UE4中C++17的...符号及enable_if_t的用法及SFINAE思想
数据结构·c++·ue4
zandy101132 分钟前
LLM与数据工程的融合:衡石Data Agent的语义层与Agent框架设计
大数据·人工智能·算法·ai·智能体
max5006001 小时前
本地部署开源数据生成器项目实战指南
开发语言·人工智能·python·深度学习·算法·开源
mljy.1 小时前
C++《C++11》(上)
c++
艾莉丝努力练剑1 小时前
GCC编译器深度解剖:从源码到可执行文件的全面探索
c++·ide·经验分享·gcc
地平线开发者1 小时前
征程 6E/M|多 camera 场景示例
算法·自动驾驶
源代码•宸2 小时前
Leetcode—721. 账户合并【中等】
c++·经验分享·算法·leetcode·并查集
緈福的街口2 小时前
【leetcode】77.组合
算法·leetcode·职场和发展
melonbo2 小时前
c++工程如何提供http服务接口
c++·http
NAGNIP2 小时前
深入 vLLM:高性能大模型推理框架解析
算法