尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

hot100 138.随机链表的复制

hot100 138.随机链表的复制
📅 发布时间:2026/6/26 10:59:21

1.题目要求:深拷贝一个链表,要求新链表中的每个节点都是新创建的,并且这些节点的random指针都指向新链表中的相应节点。

2.思路:

(1)如果没有random指针,只需要在遍历链表的同时,依此复制每个节点(创建新节点并复制val),添加在新链表的末尾。

(2)有random指针,拷贝就变得复杂了。需要知道random指向的那个节点,在新链表中是哪个节点。

(3)所以必须记录原链表节点到新链表节点的映射(map)。这样可以通过原链表random指向的节点,知道新链表的random应该指向哪个节点。

(4)难道应该使用哈希表吗?其实不需要。可以把新链表和旧链表“混在一起”。

(5)举例:有一个链表1->2->3,依次复制每个节点(创建新节点并复制val和next),把新节点直接插到原节点的后面,形成一个交错链表:1->1'->2->2'->3->3'。

(6)此时,原链表节点的下一个节点,就是其对应的新链表节点了。

(7)然后遍历这个交错链表,假如节点1的random指向节点3,那么就把节点1'的random指向节点3的下一个节点3',这样就完成了对random指针的复制。

(8)最后,从交错链表中分离出1'->2'->3',即为深拷贝后的链表。(注意:不能只删除节点1,2,3,因为题目要求原链表的next不能修改)。

3.复杂度分析:

(1)时间复杂度:O(n),其中n是链表的长度。

(2)空间复杂度:O(1),返回值不计入。

附代码:

class Solution { public Node copyRandomList(Node head) { if(head == null){ return head; } //复制每个节点,把新节点直接插到原节点的后面 for(Node cur = head;cur != null;cur = cur.next.next){ cur.next = new Node(cur.val,cur.next); //创建一个新节点:复制原节点的值,将新节点的next指向原节点的下一个节点 } //遍历交错链表中的原链表节点 for(Node cur = head;cur != null;cur = cur.next.next){ if(cur.random != null){ //要复制的random是cur.random的下一个节点 //cur表示每一个原节点 //cur.next表示每一个复制节点 //cur.next.random表示每一个复制节点的random指针 //cur.random表示每一个原节点的random指针 //cur.random.next表示每一个原节点的random指针的下一个节点,即原节点的的random指针指向节点的对应复制节点 cur.next.random = cur.random.next; } } //把交错链表分离成两个链表 Node newHead = head.next; //新链表的头是原链表头的复制节点 Node cur = head; //表示当前处理的原节点 //cur在循环外声明,是为了保证后面循环结束后仍可以访问cur for(;cur.next.next != null;cur = cur.next){ //当cur后面至少有两个节点时继续循环,因为要保证当前原节点有复制节点和下一个原节点 Node copy = cur.next; //用copy表示当前复制节点 cur.next = copy.next; //原节点指向下一个原节点 copy.next = copy.next.next; //复制节点指向下一个复制节点 } // cur.next.next == null时,循环结束,此时cur指向最后一个原节点 cur.next = null; //恢复最后一个原节点的指针指向,最后一个原节点应该指向null return newHead; } }

相关新闻

  • PyTorch-CUDA-v2.6镜像中配置Jupyter Notebook主题美化界面
  • PyTorch-CUDA-v2.6镜像中实现Early Stopping防止过拟合
  • Infineon TC3xx上运行AUTOSAR OS的时钟系统配置操作指南

最新新闻

  • MPC8360E定时器深度解析:从PIT心跳到GTM多功能应用实战
  • MPC8315E IPIC中断控制器配置详解:优先级管理与实战避坑指南
  • 第 6 篇:HTTP 状态码大全 —— 200 之外的秘密世界
  • 3分钟掌握B站缓存视频转换:m4s无损转MP4完全指南
  • DeepSeek V4 Pro本地部署实战:长文本、中文优化与MoE推理调优
  • lessmsi技术深度解析:Windows Installer文件逆向工程与提取架构设计

日新闻

  • Qwen2.5-Turbo百万上下文实战指南:百炼平台长文本处理全解析
  • 怎么监控对标账号更新,2026年作者监控工作流,5款深度对比
  • EdgeRemover:专业级Windows Edge浏览器管理工具,彻底解决顽固软件卸载难题

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号