我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python怎么实现克隆图

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python怎么实现克隆图

本篇内容介绍了“Python怎么实现克隆图”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

题目:

给定无向连通图中一个节点的引用,返回该图的深拷贝(克隆)。图中的每个节点都包含它的值 val(Int) 和其邻居的列表(list[Node])。

示例:

Python怎么实现克隆图

输入:{"$id":"1","neighbors":[{"$id":"2","neighbors":[{"$ref":"1"},{"$id":"3","neighbors":[{"$ref":"2"},{"$id":"4","neighbors":[{"$ref":"3"},{"$ref":"1"}],"val":4}],"val":3}],"val":2},{"$ref":"4"}],"val":1}解释:节点 1 的值是 1,它有两个邻居:节点 2 和 4 。节点 2 的值是 2,它有两个邻居:节点 1 和 3 。节点 3 的值是 3,它有两个邻居:节点 2 和 4 。节点 4 的值是 4,它有两个邻居:节点 1 和 3 。

提示:

  1. 节点数介于 1 到 100 之间。

  2. 无向图是一个简单图,这意味着图中没有重复的边,也没有自环。

  3. 由于图是无向的,如果节点 p 是节点 q 的邻居,那么节点 q 也必须是节点 p 的邻居。

  4. 必须将给定节点的拷贝作为对克隆图的引用返回。

解题思路:

涉及到图的遍历无非就是DFS(深度优先搜索)、BFS(广度优先搜索),可以先看前几日的这篇文章:

BFS就需要借助队列实现,DFS可以借助栈也可以直接用递归实现。就这道题而言直接用递归更好一些,无需开辟额外的数据结构空间记录节点。BFS、DFS写法相对固定,建议花点时间一次性理解透,一劳永逸。

这道题思路很清晰,关键点是如何深拷贝随机节点,可以参考链表的这篇文章:LeetCode 138:复制带随机指针的链表 Copy List with Random Pointer

链表是线性的,可以 复制节点到每个节点之后,很巧妙的完成深拷贝。显然图这样的树状结构无法用这种方法,只能借助数据结构记录已拷贝过的节点。这种需要映射新旧节点关系自然就是用散列表(字典)。

Java:

class Solution { public Node cloneGraph(Node node) { if (node == null) return node; Queue<Node> queue = new LinkedList<>();//借助队列实现BFS Map<Node, Node> map = new HashMap<>();//哈希映射 Node head = new Node(node.val, new ArrayList<>());//头节点 map.put(node, head);//哈希映射原节点和新节点 queue.add(node);//原节点加入到队列 while (!queue.isEmpty()) {//队列不为空就重复循环 Node tmp = queue.poll();//弹出队列头节点 for (Node n : tmp.neighbors) {//遍历邻居节点 if (!map.containsKey(n)) {//字典的键不包含该节点时 map.put(n, new Node(n.val, new ArrayList<>()));//新建映射关系加入字典 queue.add(n);//加入队列 } map.get(tmp).neighbors.add(map.get(n));//加入邻居节点 } } return head; }}

Python3:

class Solution: def cloneGraph(self, node: 'Node') -> 'Node': if not node: return node head = Node(node.val, [])#头节点 map = {node: head}#初始化字典,并建立新旧节点的映射关系 queue = collections.deque()#队列 queue.append(node)#原节点加入队列 while queue:#队列不为空 tmp = queue.popleft()#弹出队列头节点 for n in tmp.neighbors:#遍历邻居节点 if n in map.keys():#n节点存在于字典的键里时 map[tmp].neighbors.append(map[n])#直接加入到新节点的邻居节点 else: map[n] = Node(n.val, [])#新建节点并建立映射关系 map[tmp].neighbors.append(map[n])#由新建的映射关系取出节点并加入邻居节点 queue.append(n)#该邻居节点加入队列 return head

DFS:

递归完成的深度优先搜索非常简洁,比较容易理解,唯一要注意的就是需要把字典定义在函数外。

Java:

class Solution { Map<Node, Node> map = new HashMap(); public Node cloneGraph(Node node) { if (node == null) return node; map.put(node, new Node(node.val, new ArrayList<>()));//每次都要新建节点并建立映射关系 for (Node n : node.neighbors) { if (map.containsKey(n)) map.get(node).neighbors.add(map.get(n)); else map.get(node).neighbors.add(cloneGraph(n)); } return map.get(node); }}

Python3:

class Solution: map = dict() def cloneGraph(self, node: 'Node') -> 'Node': if not node: return node self.map[node] = Node(node.val, []) for n in node.neighbors: if n in self.map.keys(): self.map[node].neighbors.append(self.map[n]) else: self.map[node].neighbors.append(self.cloneGraph(n)) return self.map[node]

注意:

python中的字典取values时可以 dict().get(key) 也可以 dict[key] 时间复杂度都为1,但是在做算法题时肯定要用 dict[key] 这种方式。因为 get() 方法虽然效果一样,但是反复调用函数造成的时间消耗非常高,python语言本来就慢,应该养成尽可能优化代码的习惯

“Python怎么实现克隆图”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python怎么实现克隆图

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python怎么实现克隆图

本篇内容介绍了“Python怎么实现克隆图”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!题目:给定无向连通图中一个节点的引用,返回该图的深拷
2023-06-02

java怎么实现对象克隆

在Java中,可以通过两种方式来实现对象克隆:浅拷贝和深拷贝。1. 浅拷贝:使用Object类的clone()方法进行对象的浅拷贝。浅拷贝会创建一个新的对象,将原始对象的非静态字段的值复制到新对象中,对于引用类型的字段,复制的是引用而不是对
2023-08-18

Java对象克隆怎么实现

本篇内容主要讲解“Java对象克隆怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java对象克隆怎么实现”吧!1. Overiew在实际编程中,我们经常会遇到这样一个情景:有一个对象A,
2023-06-17

java克隆模式怎么实现

在Java中,克隆模式可以通过实现Cloneable接口和重写Object类的clone()方法来实现。下面是一个简单的例子:首先,创建一个可克隆的原型类:```javapublic class Prototype implements C
2023-08-30

VB.NET中怎么实现对象克隆

VB.NET中怎么实现对象克隆,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在3DMAX里面,做好一个物体(父物体)以后,可以选择Edit菜单中的Clone,下面有三中选项
2023-06-17

php中如何实现克隆

小编给大家分享一下php中如何实现克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!定义:克隆对象clone,即通过已有的对象复制一个新的同样的对象,但是两者之间
2023-06-14

C++中怎么利用LeetCode克隆无向图

这期内容当中小编将会给大家带来有关C++中怎么利用LeetCode克隆无向图,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。[LeetCode] 133. Clone Graph 克隆无向图Given a
2023-06-20

怎么克隆github代码

在近年来的软件开发中,Github已经成为程序员们必不可少的在线代码托管平台之一。对于一些相同或类似的项目,从头开始编写代码费时费力,此时借鉴或重复利用已有的代码就成为了一种常见的方式。本文将介绍如何从Github上克隆代码。一、了解Git
2023-10-22

git无法克隆怎么办

Git是一款非常流行的版本控制工具,被广泛应用于软件开发领域。然而,有时候我们会遇到一些问题,其中之一就是git无法克隆的问题。出现这种问题会让我们无法参与到项目中来,无法获取代码进行开发和测试。本篇文章将会介绍一些常见的原因和对应的解决方
2023-10-22

OpenCV如何实现无缝克隆算法

这篇“OpenCV如何实现无缝克隆算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“OpenCV如何实现无缝克隆算法”文章吧
2023-07-02

git克隆的密匙怎么弄

对于使用 git 进行代码管理的开发人员来说,git 克隆(clone)操作是非常常见的。通过克隆操作,开发者可以将一个远程仓库中的代码下载到本地进行开发和修改。而在进行 git 克隆的过程中,需要使用密匙来进行身份认证,以保证操作的安全性
2023-10-22

git克隆失败怎么解决

这篇文章主要讲解了“git克隆失败怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“git克隆失败怎么解决”吧!git克隆失败的解决办法:1、执行“git config --global
2023-06-21

如何实现centos复制克隆改网卡

这篇文章主要讲解了“如何实现centos复制克隆改网卡”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现centos复制克隆改网卡”吧!1.备份etc/udev/rules.d/70-p
2023-06-10

腾讯云服务器怎么克隆

腾讯云服务器是一种云端服务器,可以在本地进行远程管理和配置。如果你想克隆你自己的服务器,那么你需要注意以下几点:正确配置你的应用程序:在克隆你的云服务器之前,你需要正确配置你的应用程序和服务器。确保你已经安装了最新版本的应用程序和设置,例如数据库、网络设置等,以便克隆过程可以轻松完成。选择合适的云服务器:在选择云服务器时,你应该选择一家可靠的公司或者云服务提供商。这些公司应该对你的数据和网络安全有一定的保障...
2023-10-27

mac怎么用git克隆远程库

随着软件工程的不断发展,版本控制工具已经成为了开发中必不可少的一部分。Git,作为当前最流行的分布式版本控制工具,已经广泛应用于软件开发和协作中。在使用Git的过程中,克隆(Clone)远程仓库是一个非常常见的操作,特别是在团队协作中。如果
2023-10-22

怎么克隆GitHub博客到Gitee上

本篇内容介绍了“怎么克隆GitHub博客到Gitee上”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在将GitHub博客克隆至Gitee上之
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录