当前位置: 首页 > news >正文

企业做网站建设/如何创建自己的个人网站

企业做网站建设,如何创建自己的个人网站,网站建设基本要求,则么建立自己的网站LeetCode 热题 100 | 138. 随机链表的复制 大家好,今天我们来解决一道经典的链表问题——随机链表的复制。这道题在 LeetCode 上被标记为中等难度,要求深拷贝一个带有随机指针的链表。 问题描述 给你一个长度为 n 的链表,每个节点包含一个额…

LeetCode 热题 100 | 138. 随机链表的复制

大家好,今天我们来解决一道经典的链表问题——随机链表的复制。这道题在 LeetCode 上被标记为中等难度,要求深拷贝一个带有随机指针的链表。


问题描述

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

示例 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
  • -10^4 <= Node.val <= 10^4
  • Node.randomnull 或指向链表中的节点。

解题思路

核心思想
  1. 三步法

    • 第一步:在每个原节点后面插入一个新节点,新节点的值与原节点相同。
    • 第二步:设置新节点的 random 指针,利用原节点的 random 指针来设置新节点的 random 指针。
    • 第三步:将原链表和新链表分离,恢复原链表,提取新链表。
  2. 哈希表法

    • 使用一个哈希表存储原节点和新节点的映射关系。
    • 遍历原链表,创建新节点并设置 nextrandom 指针。

方法一:三步法

步骤 1:复制每个节点并插入到原节点后面
current = head
while current:new_node = Node(current.val)new_node.next = current.nextcurrent.next = new_nodecurrent = new_node.next
步骤 2:设置新节点的 random 指针
current = head
while current:if current.random:current.next.random = current.random.nextcurrent = current.next.next
步骤 3:分离原链表和新链表
current = head
new_head = head.next if head else None
while current:new_node = current.nextcurrent.next = new_node.nextif new_node.next:new_node.next = new_node.next.nextcurrent = current.next

完整代码实现

class Solution:def copyRandomList(self, head: 'Node') -> 'Node':if not head:return None# 第一步:复制每个节点并插入到原节点后面current = headwhile current:new_node = Node(current.val)new_node.next = current.nextcurrent.next = new_nodecurrent = new_node.next# 第二步:设置新节点的 random 指针current = headwhile current:if current.random:current.next.random = current.random.nextcurrent = current.next.next# 第三步:分离原链表和新链表current = headnew_head = head.nextwhile current:new_node = current.nextcurrent.next = new_node.nextif new_node.next:new_node.next = new_node.next.nextcurrent = current.nextreturn new_head

方法二:哈希表法

步骤 1:创建哈希表存储原节点和新节点的映射关系
node_map = {}
current = head
while current:node_map[current] = Node(current.val)current = current.next
步骤 2:设置新节点的 nextrandom 指针
current = head
while current:if current.next:node_map[current].next = node_map[current.next]if current.random:node_map[current].random = node_map[current.random]current = current.next

完整代码实现

class Solution:def copyRandomList(self, head: 'Node') -> 'Node':if not head:return None# 创建哈希表存储原节点和新节点的映射关系node_map = {}current = headwhile current:node_map[current] = Node(current.val)current = current.next# 设置新节点的 next 和 random 指针current = headwhile current:if current.next:node_map[current].next = node_map[current.next]if current.random:node_map[current].random = node_map[current.random]current = current.nextreturn node_map[head]

复杂度分析

  • 三步法

    • 时间复杂度:O(n),其中 n 是链表的长度。每个节点被处理三次。
    • 空间复杂度:O(1),只使用了常数级别的额外空间。
  • 哈希表法

    • 时间复杂度:O(n),其中 n 是链表的长度。每个节点被处理两次。
    • 空间复杂度:O(n),使用了哈希表存储原节点和新节点的映射关系。

示例运行

示例 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]]

总结

通过三步法或哈希表法,我们可以高效地完成带有随机指针的链表的深拷贝。三步法利用链表的结构特点,避免了额外的空间开销,而哈希表法则更直观,但需要额外的空间。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!

http://www.whsansanxincailiao.cn/news/31948068.html

相关文章:

  • 石家庄市住房和建设局网站/平台seo什么意思
  • 网站内容管理流程图/推广平台
  • 电子商务网站建设期末考试/百度指数怎么刷指数方法
  • 武汉电商网站开发/网络推广和seo
  • 长春找工作哪个网站好/软件推广的渠道是哪里找的
  • 博彩网站做代理赚钱吗/深圳百度关键词
  • 杏坛餐饮网站建站/百度发广告怎么发
  • 品牌网站设计制作价格/太原优化排名推广
  • 网站设计 网站推广 网站优化/百度指数有哪些功能
  • 曲阜公司网站建设价格/短视频推广渠道
  • 网页设计ai/网络营销乐云seo
  • 搭建网站需要注意什么/下载优化大师app
  • uniapp怎么做淘客网站/营销课程培训视频
  • 有没有做宠物的网站/seo课程培训机构
  • 网站制作作业/台州seo排名扣费
  • 微企帮做网站/友情链接交换
  • WordPress多站点默认设置/百度小说排行榜2020前十名
  • 三丰云做网站步骤/百度保障客服电话
  • 网站的点击率/持续优化疫情防控举措
  • 企业做网站公司哪家好/关于网络推广的方法
  • 南宁seo/搜索引擎优化效果
  • 做ppt用什么网站好/推广app平台有哪些
  • 华大网站建设/小红书kol推广
  • pconline太平洋电脑网/太原seo排名收费
  • wordpress 多说头像/排名优化课程
  • 石家庄建委网站官网/线上营销手段有哪些
  • 怎么用自己的网站做网页/推广产品
  • 如何设计微商城网站建设/杭州seo网站建设靠谱
  • 如何查一个网站的备案号/惠州seo网站排名
  • 网站建设中源码下载/公司网站免费建站