LeetCode如何实现复杂链表的复制
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,这篇文章主要为大家展示了"LeetCode如何实现复杂链表的复制",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何实现复杂链表的复制"这篇
千家信息网最后更新 2025年12月04日LeetCode如何实现复杂链表的复制
这篇文章主要为大家展示了"LeetCode如何实现复杂链表的复制",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何实现复杂链表的复制"这篇文章吧。
题目描述
请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。
-10000 <= Node.val <= 10000 Node.random 为空(null)或指向链表中的节点。 节点数目不超过 1000 。
题目样例
示例
输入
head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
输出
[[7,null],[13,0],[11,4],[10,2],[1,0]]
题目思考
如何处理 random 指针?
解决方案
思路
如果只有 next 指针的话很简单, 我们只需要对每个节点新建一个相同值的节点, 并保持指向关系, 逐个遍历过去即可 现在多了个 random 指针, 想要定位新的指向的节点, 一个比较自然的想法就是额外维护一个老节点到新节点的映射关系, 可以用字典来实现 第一遍遍历, 就只关注 next 部分, 并建立好映射关系 第二遍遍历, 考虑 random 部分, 找到对应的新链表的节点, 然后当前节点的 random 指针指向它即可
复杂度
时间复杂度 O(N)每个节点只需要遍历两次 空间复杂度 O(N)额外需要一个字典
代码
class Solution:
def copyRandomList(self, head: 'Node') -> 'Node':
if not head:
return None
maps = {}
# 第一遍遍历, 建立新的链表, 以及老节点到新节点的映射关系
copyHead = Node(head.val)
origin, copy = head, copyHead
maps[origin] = copy
while origin.next:
# 新建下一个节点, 并建立next关系
copy.next = Node(origin.next.val)
origin = origin.next
copy = copy.next
maps[origin] = copy
# 第二遍遍历, 处理random指针部分
origin, copy = head, copyHead
while origin:
if origin.random:
# 如果老节点random指针指向非空的话, 就将当前新节点也指向随机节点对应的新节点
copy.random = maps[origin.random]
origin = origin.next
copy = copy.next
return copyHead以上是"LeetCode如何实现复杂链表的复制"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
节点
复杂
指向
指针
内容
复杂度
篇文章
部分
题目
字典
学习
帮助
相同
代码
函数
只有
就是
思路
想法
数目
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
互联网科技素材海报
分红系统软件开发
智能家电软件开发前景
互联网小镇网络安全
哪里云服务器便宜
网络技术学习好物
关于网络安全与执法安全的论文
香港云服务器免费试用
符合统计学课程要求的数据库
湖北联想服务器虚拟化定制
饥荒联机版服务器模组怎么打开
关于网络安全的稿
58158.com当地服务器
欧柏泰克互联网科技学院19年
管理台云服务器
amd 服务器Rome GMI
美国网络安全股股价
江苏进口软件开发推荐咨询
排队执行缓解数据库压力
电子商务跟网络技术
工艺设计软件开发
vss加密服务器管理
主要数据库品牌
tnt跑酷的服务器地址
专家数据库系统制作
购票app软件开发多少钱
太原软件开发工资待遇
数据库的东西复制不了
小布什美国网络安全
品质网络技术服务直销价格