《程序员面试金典(第6版)》面试题 02.01. 移除重复节点(哈希映射,多指针暴力破解,链表)

news2024/12/28 18:11:49

题目描述

编写代码,移除未排序链表中的重复节点。保留最开始出现的节点。
题目传输门:面试题 02.01. 移除重复节点

示例1:

输入:[1, 2, 3, 3, 2, 1]
 输出:[1, 2, 3]

示例2:

 输入:[1, 1, 1, 1, 2]
 输出:[1, 2]

提示:

  • 链表长度在[0, 20000]范围内。
  • 链表元素在[0, 20000]范围内。

进阶:

  • 如果不得使用临时缓冲区,该怎么解决?

解题思路与代码

  • 这道题是一道比较简单的题。主要考验的是你对链表这种数据结构的操作能力。比如如何删除一个节点。其次呢,还可能考察了你如何使用哈希映射去去重的能力。

具体呢这道题有两种做法,接下来就让我们仔细分析一下这两种做法各有什么区别。

方案一:哈希映射找出多余的节点后删除

  • 这种方法主要就是依靠哈希映射去看看元素有没有被重复添加,我们在这里面使用到了unordered_set这种数据结构。之后我们遍用双指针法去遍历整个链表,去删除重复的元素

具体的代码如下:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* removeDuplicateNodes(ListNode* head) {
        if(head == nullptr || head->next == nullptr) return head;
        unordered_set<int> set;
        ListNode * prev = nullptr;
        ListNode * curr = head;
        while(curr){
            if(set.count(curr->val)){
                ListNode * temp = curr->next;
                prev->next = temp;
                ListNode * dNode = curr;
                curr = curr->next;
                dNode = nullptr;
                delete dNode;
                continue;
            }
            set.insert(curr->val);
            prev = curr;
            curr = curr->next;
        }
        return head;
    }
};

复杂度分析

时间复杂度:

  • 我们只是遍历了一遍链表,所以时间复杂度是O(n)

空间复杂度:

  • 我们用到了unordered_set数据结构,最多存储n个数据,所以空间复杂度也是O(n)
    在这里插入图片描述

方案二:多指针暴力破解

  • 这种方法其实就更无脑了。有点像双层for循环。只不过我们这里用while循环,使用多个指针,依次对比每一个元素是否重复,之后删除掉

具体代码如下:

class Solution {
public:
    ListNode* removeDuplicateNodes(ListNode* head) {
        if(head == nullptr || head->next == nullptr) return head;
        ListNode * slow = head;
        
        while(slow != nullptr){
            ListNode * prev = slow;
            ListNode * curr = slow->next;
            while(curr != nullptr){
                if(slow->val == curr->val){
                    ListNode * temp = curr->next;
                        delete curr;
                        prev->next = temp;
                        curr = temp;
                        continue;
                }
                prev = curr;
                curr = curr->next;
            }
            slow = slow->next;
        }
        return head;
    }
};

在这里插入图片描述

复杂度分析

时间复杂度:因为是双层遍历,所以时间复杂度为O(n^2)
空间复杂度:因为没有使用多余的数据结构,所以空间复杂度是O(1)

总结

这道题主要是为了测试以下几个方面的能力:

  • 基础数据结构理解:理解和处理链表是编程和数据结构中的基本技能。你需要了解如何遍历链表、如何修改链表节点之间的连接,以及如何在链表中插入和删除节点。

  • 编程技巧:这道题需要你实现一个功能,去除链表中的重复元素。这既可以考察你对于基础算法的理解,也可以考察你编程的技巧和代码质量,例如,你能否写出没有内存泄漏的代码。

  • 空间和时间复杂度权衡:这道题的进阶部分是在不使用额外空间的情况下解决问题,这就需要你去考虑如何在空间和时间复杂度之间做出权衡。在许多真实世界的问题中,空间和时间常常是一对矛盾,有时需要牺牲时间来换取空间,有时则需要牺牲空间来换取时间。

  • 问题解决策略:最初的问题可以用哈希表简单解决,但进阶问题则需要改变策略。这能帮助你学会如何针对不同的约束条件选择不同的解决方案,这在实际的软件开发工作中是非常重要的。

总的来说,这道题是一道非常好的综合性编程题,可以全面考察你的编程能力。

最后的最后,如果你觉得我的这篇文章写的不错的话,请给我一个赞与收藏,关注我,我会继续给大家带来更多更优质的干货内容

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/559180.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Hive---拉链表设计与实现

1 数据同步问题 Hive在实际工作中主要用于构建离线数据仓库&#xff0c;定期的从各种数据源中同步采集数据到Hive中&#xff0c;经过分层转换提供数据应用。比如每天需要从MySQL中同步最新的订单信息、用户信息、店铺信息等到数据仓库中&#xff0c;进行订单分析、用户分析。 …

【C++修炼之路】定位new(项目记录)

————————————每一个不曾起舞的日子都是对生命的辜负。 C之定位new 1. 什么是定位new2. 定位new的语法3. 具体实例 1. 什么是定位new 一般的new运算符负责在heap堆中找到一个足以能够满足要求的内存块。 而定位new&#xff08;Placement new&#xff09;是C中的一…

运行100万个并发任务,不同语言各需要多少内存

作者&#xff1a;DataStax 公司&#xff08;美国的一家数据库系统开发商&#xff09;Piotr Kołaczkowski 原文见&#xff1a; https://pkolaczk.github.io/memory-consumption-of-async/ 在这篇博客文章中&#xff0c;探讨了处理大量网络连接时候的Rust、Go、Java、C#、Pyth…

企企通“码上顺”清洗工具 | 让数据更有价值,让业务更出色

数据清理工作是企业数据管理、数据治理中的最基础的工作之一&#xff0c;不仅是一项苦活、累活&#xff0c;也是一个既考验业务又检验技术的活。 物料主数据作为企业核心的数据资产&#xff0c;在智慧供应链、业财一体化等数字化建设中发挥着重要作用。在当今高速发展的商业环…

《汇编语言》- 读书笔记 - 实验2 用机器指令和汇编指令编程

《汇编语言》- 读书笔记 - 实验2 用机器指令和汇编指令编程 1. 预备知识: Debug 的使用2 .实验任务 1. 预备知识: Debug 的使用 统一完善到&#xff1a;实验 1 查看 CPU 和内存&#xff0c;用机器指令和汇编指令编程。不在这拆开写了。 2 .实验任务 使用 Debug&#xff0c;将…

功率放大器在压电驱动器中的作用及应用

功率放大器在压电驱动器中的作用是将低功率信号放大为足够大的电力信号&#xff0c;以驱动压电陶瓷材料产生相应的机械振动。 压电陶瓷材料是一种特殊的陶瓷材料&#xff0c;能够将机械能转换为电能&#xff0c;因此被广泛应用于各种类型的振动器件和传感器中。这些器件通常需要…

Combiner

概述 Conbiner在MapReduce的Shuffle阶段起作用&#xff0c;它负责局部数据的聚合&#xff0c;我们可以看到&#xff0c;对于大数据量&#xff0c;如果没有Combiner&#xff0c;将会在磁盘上写入多个文件等待ReduceTask来拉取&#xff0c;但是如果有Combiner组件&#xff0c;我们…

5 个章节、25 条规范,全方位 Get 数据集选择与创建的「百科全书」

By 超神经 内容一览&#xff1a;如果你正在学习如何创建或选择一个合适的数据集&#xff0c;那么这篇文章会给你一些实用的建议&#xff0c;帮助你在选择和创建数据集时做出明智的决策。 关键词&#xff1a;机器学习 数据集 本文首发自 HyperAI 超神经微信公众平台~ 作者 |…

星标3.5k,一款国产的轻量级开源在线项目任务管理工具

今天给大家推荐一个轻量级的开源在线项目任务管理工具&#xff1a;DooTask 图片 DooTask 提供各类文档协作工具、在线思维导图、在线流程图、项目管理、任务分发、即时IM&#xff0c;文件管理等工具。 高效便捷的团队沟通工具 针对项目和任务建立群组&#xff0c;工作问题可…

SRP Batcher在真机上失效

1&#xff09;SRP Batcher在真机上失效 ​2&#xff09;Shader里面对同一张纹理多次采样会影响效率吗 3&#xff09;为什么纹理开启了mipmap后&#xff0c;纹理内存反而下降了 4&#xff09;TMP为什么有多次Delegate.Combine()的GC 这是第336篇UWA技术知识分享的推送&#xff0…

如何减少电脑内存占用?

内存(Memory)是计算机一个重要的组成部件&#xff0c;也称为内存储器或主存储器。它可以暂时存放CPU中运算的数据&#xff0c;以及与硬盘等外部存储器交换的数据&#xff0c;是CPU和硬盘之间的桥梁。若电脑内存占用过高&#xff0c;这会影响到电脑运行的速度&#xff0c;那该如…

网络安全行业推荐考取的证书有哪些?

下面就让知白小编来给解读一下这个问题~作为网络安全行业从业者或者相关专业的大学生&#xff0c;如果相应的职业证书在手&#xff0c;肯定是会身价倍增。 咳咳&#xff0c;但是如果你还是网络安全小白&#xff0c;知白小编不建议你直接去考认证&#xff0c;应该是先打好基础学…

三、LLC 谐振变换器

电压增益特性分析 根据搭建的 LLC 谐振变换器主电路等效模型&#xff0c;可推导出变换器直流电压 增益为 M&#xff1a; λ 4时的增益曲线如下图所示&#xff1a; 根据变换器直流电压增益表达式&#xff0c;利用 Mathematica 绘制出λ4 时&#xff0c;变换器取不同 Q 值的直…

创建型设计模式01-简单工厂模式

✨作者&#xff1a;猫十二懿 ❤️‍&#x1f525;账号&#xff1a;CSDN 、掘金 、个人博客 、Github &#x1f389;公众号&#xff1a;猫十二懿 这里只是简单的将《大话设计模式【Java溢彩加强版】》的内容简单是复述一下&#xff0c;并加上自己的理解 简单工厂模式 1、引入问…

windows环境下sublime的nodejs插件详细安装图解

前面的话 搜索了好多文档后&#xff0c;才成功地安装了sublime text3的nodejs插件。为了存档&#xff0c;也为了方便有同样需求的朋友&#xff0c;将其安装过程详细记录如下 安装nodejs 虽然nodejs官网提供了node的msi文件&#xff0c;但本人在win7系统下多次尝试&#xff0c;…

在阿里干了6年自动化测试,30岁即将退休的我,告诉你自动化测试工程师有多吃香...

测试人员需要具备自动化测试或者测试开发能力&#xff0c;已经成为测试行业内容的一种显在趋势&#xff0c;而且这种趋势呈放大态势&#xff0c;其发展前景是十分明朗的。 2022这种疫情期间&#xff0c;就业大环境不是很理想&#xff0c;目前呢&#xff0c;企业倾向于招自动化…

Win11下Microsoft Store安装Ubuntu报错解决指南

目录 从Microsoft Store下载Ubuntu下载安装完毕后&#xff0c;打开安装时报错&#xff1a; 一. WslRegisterDistribution failed with error: 0x8007019e 二. WslRegisterDistribution failed with error: 0x800701bc 如果帮到你的话&#xff0c;麻烦点个免费的关注吧bro♥…

测试开发工程师的薪资上限究竟在哪?年薪50W都不是梦...

在说测试开发工程师的薪资待遇之前&#xff0c;咱们要先了解软件测试岗位是用来做什么的&#xff0c;岗位是否重要&#xff0c;只有你知道了这些&#xff0c;才能判断这个岗位是否有价值&#xff01;软件测试是依据需求分析和测试用例&#xff0c;运用手工和自动化的手段来验证…

市场需求升级,cv5200带来新的WiFi传输解决方案,远距离无线通信技术

近年来&#xff0c;随着无线通信技术的不断发展&#xff0c;越来越多的应用需要高速率、远距离、稳定的数据传输。 远距离WiFi传输是指通过WiFi信号实现在远距离范围内的无线通信和数据传输。 为此&#xff0c;cv5200采用了先进的技术&#xff0c;并提供了较远的传输距离、高…

高速高密PCB高级验证技巧(四): 扫除信号线的意外回音

现今电子产品复杂度越趋增加&#xff0c;信号速度越来越快&#xff0c;在信号传输的过程中&#xff0c;如果信号不断反射便会对电子产品的运作造成影响&#xff0c;而这又与阻抗连续性以及阻抗匹配息息相关&#xff1b;而如何避免信号反射&#xff0c;除了在硬件设计时的规划外…