一起学习LeetCode热题100道(32/100)

news2025/1/10 17:53:23

32.随机链表的复制(学习)

给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。
构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的 next 指针和 random 指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点 。

例如,如果原链表中有 X 和 Y 两个节点,其中 X.random --> Y 。那么在复制链表中对应的两个节点 x 和 y ,同样有 x.random --> y 。
返回复制链表的头节点。
用一个由 n 个节点组成的链表来表示输入/输出中的链表。每个节点用一个 [val, random_index] 表示:
val:一个表示 Node.val 的整数。
random_index:随机指针指向的节点索引(范围从 0 到 n-1);如果不指向任何节点,则为 null 。
你的代码 只 接受原链表的头节点 head 作为传入参数。

示例 1:
在这里插入图片描述
输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]

示例 2:
在这里插入图片描述
输入:head = [[1,1],[2,1]]
输出:[[1,1],[2,1]]

示例 3:
在这里插入图片描述
输入:head = [[3,null],[3,0],[3,null]]
输出:[[3,null],[3,0],[3,null]]

提示:
0 <= n <= 1000
-104 <= Node.val <= 104
Node.random 为 null 或指向链表中的节点。

解析:
一、在原节点后插入拷贝节点
遍历原链表,并在每个原节点后面插入一个新的拷贝节点。新节点的val与原节点相同,next和random暂时为空。此时,链表变成了原节点 -> 拷贝节点 -> 原节点 -> 拷贝节点 -> …的形式。

二、设置拷贝节点的random指针
再次遍历链表,但这次是两个节点(一个原节点,一个拷贝节点)作为一组一起遍历。对于每组中的拷贝节点,如果原节点的random不是空,则将拷贝节点的random指针指向原节点random的下一个节点(即对应的拷贝节点)。

三、拆分链表
最后,我们需要将原链表和拷贝链表拆分。创建一个哑节点dummy来辅助构建新的链表。然后,再次遍历链表,但这次是将原链表的next指针恢复(即指向下一个原节点),并将拷贝节点链接到新的链表上。

四、返回值
最后,返回哑节点的next,即新链表的头节点。

var copyRandomList = function(head) {
    if (!head) return null;  
  
    // 第一次遍历:在原节点后复制新节点  
    let curr = head;  
    while (curr) {  
        const newNode = new Node(curr.val, null, null);  
        newNode.next = curr.next;  
        curr.next = newNode;  
        curr = newNode.next;  
    }  
  
    // 第二次遍历:设置复制节点的random指针  
    curr = head;  
    while (curr) {  
        if (curr.random) {  
            curr.next.random = curr.random.next;  
        }  
        curr = curr.next.next;  
    }  
  
    // 第三次遍历:拆分链表,得到复制后的链表  
    let dummy = new Node(0); // 创建一个哑节点  
    let currCopy = dummy;  
    curr = head;  
    while (curr) {  
        currCopy.next = curr.next; // curr.next 现在是复制的节点  
        curr.next = curr.next.next; // 恢复原链表的next指针  
        currCopy = currCopy.next;  
        curr = curr.next;  
    }  
  
    return dummy.next; // 返回复制链表的头节点  
};

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

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

相关文章

LLM - 使用 Ollama + OpenWebUI 在 Linux 服务器中高效部署大语言模型

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/140992533 免责声明:本文来源于个人知识与公开资料,仅用于学术交流,欢迎讨论,不支持转载。 Ollama 是一个开源的大型语言模型(LLM)服务工具,目的是简化本地运行…

java消息队列ActiveMQ

安装 前置条件 activemq的运行依赖于jdk&#xff0c;需要提前安装jdk如果已经安装了jdk&#xff0c;需要根据jdk的版本来选择对应的版本进行安装activemq版本对应在官网上&#xff0c;使用java -version 看jdk的版本注意&#xff1a;jdk和mq的版本不一致会报错&#xff0c;电脑…

Python 异步编程:Sqlalchemy 异步实现方式

SQLAlchemy 是 Python 中最流行的数据库工具之一&#xff0c;在新版本中引入了对异步操作的支持。这为使用异步框架&#xff08;如 FastAPI&#xff09;开发应用程序带来了极大的便利。在这篇文章中&#xff0c;简单介绍下 SQLAlchemy 是如何利用 Greenlet 实现异步操作的。 什…

【计算机组成原理】2.CPU的原理

CPU的原理 为什么讲线程要讲CPU&#xff1f;因为线程和CPU有一对一的对应关系&#xff01;&#xff08;超线程除外&#xff09; 当然&#xff0c;现代的计算机的核心&#xff0c;也就是芯片&#xff0c;是由10 0000 0000 个零件构成&#xff0c;我没有办法带你走遍这里面的每…

java.nio.charset.MalformedInputException: Input length = 1

1、问题 项目启动报错&#xff1a; Exception in thread "main" org.yaml.snakeyaml.error.YAMLException: java.nio.charset.MalformedInputException: Input length 1提示原因&#xff1a; Caused by: java.nio.charset.MalformedInputException: Input length 1…

机器学习-线性回顾

线性回归 线性回归1. 简介2. 线性回归问题求解3. 欠拟合与过拟合 线性回归 1. 简介 """ 简介:定义:利用回归方程对一个或多个自变量(特征值)和因变量(目标值)之间关系 进行建模的一种分析方式公式:见下图分类:一元线性回归:目标值与一个因变量有关系多远线性回…

PMP–知识卡片--盈亏平衡分析

盈亏平衡分析是通过盈亏平衡点&#xff08;BEP&#xff09;分析项目成本与收益的平衡关系的一种方法。各种不确定因素&#xff08;如投资、成本、销售量、产品价格、项目寿命期等&#xff09;的变化会影响投资方案的经济效果&#xff0c;当这些因素的变化达到某一临界值时&…

S2S服务端上报Appsflyer和Firebase事件

S2S 服务端上报 Appsflyer 和 Firebase 事件 Appsflyer 事件上报 接口文档地址&#xff1a;Send Event 你可以在 appsflyer 注册一个测试 APP 用于测试&#xff0c;选择 Android 项目比较好创建。 必填参数及 Api Secret 获取 点击在页面左侧 “Configuration - App Setting…

CentOS 介绍

引出 Linux 系统内核与 Linux 发行套件系统的区别&#xff1f; Linux 系统内核指的是一个由 Linus Torvalds&#xff08;Linux之父&#xff0c;内核主要开发者&#xff09;负责维护&#xff0c;提供硬件抽象层、磁盘、文件系统控制及多任务功能的系统核心程序。 Linux 发行套…

【Git】VS Code 中文件右侧字母(A M U)含义

VS Code项目关联git后&#xff0c;常常会出现如下标识 其中 M Modified 已经在仓库中添加过该文件&#xff0c;然后你对这个文件进行了修改&#xff0c;就会文件后标记M U Untracked 本地新建了这个文件&#xff0c;还未提交到仓库上&#xff0c;就会标记U D Delete 本…

sourcemap使用

sourcemap是什么以及怎么生成就不过多阐述了&#xff0c;这是之前看到的一篇文章感觉介绍的很详细&#xff1a;弄懂 SourceMap&#xff0c;前端开发提效 100% 浏览器加载sourcemap 我们线上代码一般不会开启sourcemap&#xff0c;在排查线上的问题时&#xff0c;可以通过浏览器…

信创安全 | 新一代内网安全方案—零信任沙盒

在当今数字化时代&#xff0c;访问安全和数据安全成为企业面临的重要挑战。传统的边界防御已经无法满足日益复杂的内网办公环境&#xff0c;层出不穷的攻击手段已经让市场单一的防御手段黔驴技穷。当企业面临越来越复杂的网络威胁和数据泄密风险时&#xff0c;更需要一种综合的…

S4 HANA标准现金流量表(IDCNCASH、J3RKKRS、J3RKKRD)

文章目录 一、概述二、配置2.1、路径2.2、说明事项2.3、现金流项目及会计科目 一、概述 传统输出现金流量表步骤&#xff08;直接法现金流表&#xff09;&#xff1a; 定义现金流变动相关的原因代码&#xff08;Reason Code&#xff09;&#xff1b;过账凭证里指定对应的原因…

python开发上位机 - PyCharm环境搭建、安装PyQt5及工具

目录 简介&#xff1a; 一、安装PyCharm 1、下载 PyCharm 2、PyCharm安装 1&#xff09;配置安装目录 2&#xff09;安装选项 3、问题及解决方法 二、安装PyQt5 1、打开 Pycharm&#xff0c;新建 Project 2、安装 pyqt5 3、安装很慢怎么办&#xff1f; 4、安装 pyq…

数据库规范化设计 5大基本原则

规范化设计原则是数据库设计的基本原则&#xff0c;有助于减少数据冗余&#xff0c;提高数据一致性和完整性&#xff0c;简化数据管理&#xff0c;增强数据安全性&#xff0c;对整个开发项目至关重要。而缺乏规范化设计会导致数据冗余&#xff0c;增加存储成本&#xff0c;引发…

【视频编码】调用x264库文件实现编码

调用x264库文件实现编码 整理前面记录的文章时发现还没有记录过如何实际操作x264编码器实现编码的功能&#xff0c;过去是通过FFmpeg调用libx264的接口来实现编码功能&#xff0c;这里记录一下直接调用x264的接口来实现编码的功能&#xff0c;同时存储编码之后的码流和重建的yu…

线上预约陪诊平台医院陪诊系统源码就医陪护小程序APP开发

项目分析 随着医疗行业的数字化转型和人们对健康需求的日益增长&#xff0c;线上预约陪诊系统作为一种新兴的医疗服务模式&#xff0c;正逐渐受到市场的关注和认可。本文将从市场前景、使用人群、盈利模式以及竞品分析等多个角度&#xff0c;全面探讨线上预约陪诊系统的技术性…

Windows长文件名支持

Windows 长文件名支持 &#x1f354;打开注册表&#x1f957;激活 &#x1f354;打开注册表 &#x1f957;激活 计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem双击进入编辑模式 把0改成1&#xff0c;确定

【高校主办 | 快录用,稳定EI检索 !ACM独立出版】2024智能物联与计算国际学术会议(AITC 2024,8月30-9月1)

为探讨智能物联与计算技术所涉领域的最新研究和发展趋势&#xff0c;2024智能物联与计算学术大会&#xff08;AITC 2024&#xff09;将于2024年8月30日-9月1日在中国 贵阳举行。 AITC 2024由中国计算机学会、中国人工智能学会、浙江省科学技术协会、浙江工业大学、浙江省人工智…

Moba案例帧同步

1.设置环境光 2.搭建客户端框架 a.对上述的模块基类&#xff08;都是单例类&#xff0c;都有初始化方法&#xff09; b.隐藏登录页面&#xff08;得到Canvas的子对象失活&#xff09; c.设置根对象过场景不被移除 tip&#xff1a;模块都是继承mono的&#xff0c;不能直接ne…