全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

LeetCode 133 题解:用 DFS 正确实现图的深拷贝(含循环处理)

本文详解 leetcode 133. clone graph 的 dfs 深拷贝实现要点,重点解决因忽略图中环导致的重复节点创建问题,并提供简洁、健壮、可复用的递归解决方案。

在实现无向图的深拷贝时,一个常见误区是仅用 set 记录已访问节点值(如 visited = set()),却未保存对应克隆节点的引用。这会导致同一原始节点被多次克隆——尤其当图中存在环(cycle)或多个入边时,违反“深拷贝”要求(即结构一致 + 引用独立 + 节点唯一),最终使输出图结构错误,无法通过 LeetCode 测试用例。

核心问题在于:DFS 遍历中,若邻居节点 neighbor 已被访问过,你不应新建 Node(neighbor.val),而应复用此前已创建的克隆节点。为此,visited 必须从 set 升级为哈希映射(dict),以支持“值 → 克隆节点”的快速查找与复用。

以下是推荐的正确实现(带详细注释):

"""
# Definition for a Node.
class Node:
    def __init__(self, val=0, neighbors=None):
        self.val = val
        self.neighbors = neighbors if neighbors is not None else []
"""

from typing import Optional, Dict

class Solution:
    def cloneGraph(self, node: Optional['Node']) -> Optional['Node']:
        # visited: {original_node.val -> cloned_node}
        visited: Dict[int, 'Node'] = {}

        def dfs(n: Optional['Node']) -> Optional['Node']:
            if not n:
                return None

            # 若该节点已被克隆,直接返回缓存的克隆体(关键!处理环/多入边)
            if n.val in visited:
                return visited[n.val]

            # 否则创建新节点,并立即加入 visited(避免后续递归重复创建)
            clone = Node(n.val)
            visited[n.val] = clone

            # 递归克隆所有邻居,并挂载到当前克隆节点上
            for neighbor in n.neighbors:
                clone.neighbors.append(dfs(neighbor))

            return clone

        return dfs(node)

关键设计亮点:

  • 状态复用而非标记跳过:visited 存储的是 映射,而非布尔标记;每次进入 dfs 先查表,命中即复用,确保每个原始节点至多生成一个克隆体。
  • 无特殊边界处理:空节点、单节点、孤立节点等均由 dfs 统一处理,逻辑更简洁、鲁棒性更强。
  • 返回式递归:dfs 返回克隆节点,消除副作用参数(如原代码中的 copy 参数),符合函数式风格,降低出错概率。

⚠️ 注意事项:

  • 不可使用 id(node) 或 node 对象本身作为字典 key(因图中节点可能重复 val 但不同实例,且 LeetCode 测试环境对象身份不稳定);必须用 node.val 作为键(题设保证节点值唯一)。
  • neighbors 列表必须逐个 dfs 递归填充,不可浅拷贝(如 copy.neighbors = n.neighbors[:]),否则仍共享原始引用。
  • 本解法时间复杂度为 O(N + E),空间复杂度为 O(N)(递归栈 + visited 字典),符合最优要求。

该方案已通过 LeetCode 所有测试用例(包括含环图、大图、单节点图等),是解决图深拷贝问题的标准范式。


# node  # app  #   # 递归  # 循环  # copy  # 对象  # leetcode  # 复用  # 图中  # 已被  # 而非  # 的是  # 多个  # 遍历  # 布尔  # 不应 


相关文章: 活动邀请函制作网站有哪些,活动邀请函文案?  北京制作网站的公司,北京铁路集团官方网站?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  如何在Windows 2008云服务器安全搭建网站?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  如何在景安云服务器上绑定域名并配置虚拟主机?  建站主机选购指南:核心配置与性价比推荐解析  如何用5美元大硬盘VPS安全高效搭建个人网站?  小型网站建站如何选择虚拟主机?  如何通过虚拟主机快速搭建个人网站?  建站之星如何优化SEO以实现高效排名?  建站之星多图banner生成与模板自定义指南  如何用花生壳三步快速搭建专属网站?  ,想在网上投简历,哪几个网站比较好?  ,交易猫的商品怎么发布到网站上去?  建站之星后台管理系统如何操作?  Python多线程使用规范_线程安全解析【教程】  测试制作网站有哪些,测试性取向的权威测试或者网站?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何在阿里云香港服务器快速搭建网站?  如何选择高效响应式自助建站源码系统?  如何在万网自助建站平台快速创建网站?  广德云建站网站建设方案与建站流程优化指南  大学网站设计制作软件有哪些,如何将网站制作成自己app?  建站OpenVZ教程与优化策略:配置指南与性能提升  c# 在高并发下使用反射发射(Reflection.Emit)的性能  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  装修招标网站设计制作流程,装修招标流程?  建站之星安装后界面空白如何解决?  c# 服务器GC和工作站GC的区别和设置  太平洋网站制作公司,网络用语太平洋是什么意思?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  湖北网站制作公司有哪些,湖北清能集团官网?  如何在建站宝盒中设置产品搜索功能?  如何通过WDCP绑定主域名及创建子域名站点?  香港网站服务器数量如何影响SEO优化效果?  深圳网站制作案例,网页的相关名词有哪些?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  如何高效完成独享虚拟主机建站?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  网站制作企业,网站的banner和导航栏是指什么?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  详解jQuery停止动画——stop()方法的使用  如何在IIS中新建站点并配置端口与IP地址?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  头像制作网站在线制作软件,dw网页背景图像怎么设置? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。