iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >深拷贝一个图的方法教程
  • 305
分享到

深拷贝一个图的方法教程

2024-04-02 19:04:59 305人浏览 薄情痞子
摘要

深拷贝一个图的方法教程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言在此之前,你需要对一些概念搞清楚:什么是深拷贝、浅拷贝

深拷贝一个图的方法教程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

前言

在此之前,你需要对一些概念搞清楚:什么是深拷贝、浅拷贝?

浅拷贝:如果拷贝的是引用类型(非基本类型),就只会拷贝一层(嵌套的对象不会被拷贝),如果原对象发生改变,那么拷贝对象也会发生改变。

深拷贝:深拷贝的话会拷贝多层,嵌套的对象也会被拷贝出来,相当于开辟一个新的内存地址用于存放拷贝的对象。

用通俗一点(可能不完全确切)的话解释,浅拷贝就像你的双胞胎兄弟一样,你们父母亲人都是一样的;而深拷贝就像另一个平行的时空,那里有另一个你的一切。

既然搞懂了深浅拷贝以及其区别,我们再看看图,图一般用来表示节点和节点之间的关系,常分为有向图和无向图,在这里我们以无向图(一旦连接即双向)为主题。

我们对图的表示一般有邻接矩阵和邻接表,邻接矩阵的话比较直观的表示一个图的连通性,操作维护更简单,在Java中一般使用二维数组表示邻接矩阵,数组中的值可以表示两个节点的权值。

深拷贝一个图的方法教程

邻接矩阵表示一个图

使用邻接矩阵虽然简单但是有个比较差的就是浪费较多内存空间,所以很多情况还是使用邻接表来表示一个图,邻接表一般是数组+链表的这么一个组合。但是也有一些特殊情况各个节点比较独立的不用数组联立。

深拷贝一个图的方法教程

邻接表表示一个图

问题分析

如果这个图使用邻接表表示,给你无向 连通 图中一个节点的引用,请你返回该图的 深拷贝(克隆),这个问题是力扣131克隆图原题。

图中的每个节点都包含它的值 val(int) 和其邻居的列表(list[node])。

class Node {     public int val;     public List<Node> neighbors; }

深拷贝一个图的方法教程

图片来源力扣

给一个节点的引用,怎么克隆这个图呢?

如果只有这一个节点,那么克隆这个节点就好。如果这个节点只有一层邻居,那克隆这个邻居的列表(克隆List集合)即可。

但事实是这个节点可能有多层邻居,并且邻居之间可能存在着复杂联系。

深拷贝一个图的方法教程

可能的一个图

克隆整个图,所以图的每一个节点都要被克隆的,我们需要使用图论的搜索算法来枚举所有节点,并且在遍历的过程中我们需要想办法将节点之间的关系也克隆下来。遍历的方法可以使用dfs或者bfs,这里使用bfs来实现。

凡是遇到苦难的时候我们模拟一下这个克隆的过程即可,通过下面这张图可以大概了解克隆图的过程中,最大的问题是要避免创建重复节点。即有的节点一旦被创建它的引用可能在后面会被用到的。

深拷贝一个图的方法教程

模拟克隆的过程

那我们该如何解决这个问题呢?怎么样能够快速找到对应节点的引用?

这里最好的方法是使用HashMap,其中key保存的是被克隆图中的节点,而value是在克隆图中所对应的节点,这样在克隆新图的过程中,我们遍历被克隆图中节点邻居的时候,就可以用哈希判断这个节点对应的value是否存在(即这个节点在克隆图中是否存在)。

如果存在那么直接使用HashMap找到对应节点放入克隆图中新创建的List中。

不过不存在说明这个节点第一次遇到,克隆这个节点,先放到hashMap中与被克隆节点对应,然后放入克隆图中新创建的List中。

这个流程其中大概是这样的:

深拷贝一个图的方法教程

其中一个过程Map的变化和作用

有了上面的分析,想必你对这个问题的解决已经有了思路和想法,下面就提供一下代码实现。

  class Solution {     public Node cloneGraph(Node node) {         if(node==null)                 return null;         Map<Node, Node>map=new HashMap<Node, Node>();//节点映射克隆的节点          Queue<Node>oldqueue=new ArrayDeque<Node>();//bfs队列         oldqueue.add(node);         Node value=new Node(node.val);//先将返回的节点 创建、映射         map.put(node, value);         while (!oldqueue.isEmpty()) {             Node oldnode=oldqueue.poll();             Node newnode=map.get(oldnode);//找到这个节点对应克隆的映射(一定存在)             List<Node>list=oldnode.neighbors;//邻居             List<Node>listnew=new ArrayList<Node>();//克隆邻居             for(Node team:list)             {                 if(map.containsKey(team))                 {                     listnew.add(map.get(team));                     //点以前已经遇到,直接添加到邻居列表                 }                 else {//这个邻居第一次碰到,需要创建新节点赋予值                     Node no=new Node(team.val);                     map.put(team, no);//映射                     listnew.add(no);                     oldqueue.add(team);//这个点第一次遇到,要将它放到队列中进行bfs搜索                 }             }             newnode.neighbors=listnew;//将节点的邻居指向list         }         return value;     } }

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网node.js频道,感谢您对编程网的支持。

--结束END--

本文标题: 深拷贝一个图的方法教程

本文链接: https://www.lsjlt.com/news/83421.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 深拷贝一个图的方法教程
    深拷贝一个图的方法教程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言在此之前,你需要对一些概念搞清楚:什么是深拷贝、浅拷贝...
    99+
    2024-04-02
  • Java Cloneable接口的深拷贝与浅拷贝方法
    本篇内容主要讲解“Java Cloneable接口的深拷贝与浅拷贝方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java Cloneable接口的深拷贝与浅拷贝方法”吧!...
    99+
    2023-06-29
  • python浅拷贝与深拷贝使用方法详解
    目录一、对象赋值二、浅拷贝三、深拷贝四、深入解析浅拷贝和深拷贝在面试和日常的开发中都会经常遇到 我们就从 对象赋值、浅拷贝、深拷贝 三个方面来讲 一、对象赋值 In [1]: lis...
    99+
    2022-11-13
    python浅拷贝与深拷贝 python深拷贝 python浅拷贝
  • javascript怎么深拷贝一个对象
    这篇文章将为大家详细讲解有关javascript怎么深拷贝一个对象,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript的作用是什么1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出响应...
    99+
    2023-06-14
  • C#深拷贝方法探究及性能比较(多种深拷贝)
    目录1、手写创建对象2、反射3、Json字符串序列化4、对象二进制序列化5、AutoMapper6、表达式树之前学习了设计模式原型模式,在原型模式中就提到了对象的深拷贝。深拷贝指的是...
    99+
    2024-04-02
  • C#深拷贝的方法是什么
    今天小编给大家分享一下C#深拷贝的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。测试平台:Intel 9700K+...
    99+
    2023-06-30
  • 图解Python中浅拷贝copy()和深拷贝deepcopy()的区别
    关于浅拷贝和深拷贝想必大家在学习中遇到很多次,这也是面试中常常被问到的问题,借由这个时间,整理一下浅拷贝和深拷贝的关系 先从一个简单的例子入手吧 定义一个数组的嵌套结构 a = [1...
    99+
    2023-05-19
    Python 浅拷贝copy() Python 深拷贝deepcopy()
  • JavaScript深拷贝方法structuredClone使用
    目录正文浅拷贝与深拷贝使用 structuredClone 进行深拷贝正文 对于深拷贝,最容易也应该是常见的方法是使用 JSON.parse() + JSON.stringify(...
    99+
    2023-02-22
    JavaScript 深拷贝 JavaScript structuredClone
  • 一文带你搞懂Numpy中的深拷贝和浅拷贝
    目录1. 引言2. 浅拷贝2.1 问题引入2.2 问题剖析3. 深拷贝3.1 举个栗子3.2 探究原因4. 技巧总结4.1 判断是否指向同一内存4.2 其他数据类型5. 总结1. 引...
    99+
    2024-04-02
  • 超详细JavaScript深浅拷贝的实现教程
    目录一、浅拷贝1. Object.assign()2. 扩展运算符3. 数组浅拷贝4. 手写实现浅拷贝二、深拷贝1. JSON.stringify()2. 函数库lodash3. 手...
    99+
    2024-04-02
  • JS实现深拷贝和浅拷贝的方式详解
    目录一. 基本类型数据拷贝二. 引用类型数据拷贝1、浅拷贝2、深拷贝说道数据拷贝就离不开数据类型,在JS中数据类型分为基本类型和引用类型 基本类型: number, boolean,...
    99+
    2024-04-02
  • C#中深拷贝和浅拷贝的介绍与用法
    一、什么是深拷贝和浅拷贝 对于所有面向对象的语言,复制永远是一个容易引发讨论的题目,C#中也不例外。此类问题在面试中极其容易被问到,我们应该在了解浅拷贝和深拷贝基本概念的基础上,从设...
    99+
    2024-04-02
  • js中区分深拷贝与浅拷贝的实战过程
    目录一、自我理解二、数据存储形式(1)基本数据类型存储于栈中(2)引用数据类型存储与堆中三、怎样实现深拷贝?(1)借助JSON对象的parse和stringify(2)手写递归(3)...
    99+
    2024-04-02
  • java实现深拷贝的方法是什么
    Java实现深拷贝的方法有以下几种:1. 实现Cloneable接口并重写clone()方法:在需要深拷贝的类中实现Cloneabl...
    99+
    2023-08-14
    java
  • vue深拷贝的实现方法有哪些
    这篇文章主要讲解了“vue深拷贝的实现方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue深拷贝的实现方法有哪些”吧!vue深拷贝的三种实现方式:1、通过递归方式实现深拷贝;2、J...
    99+
    2023-07-05
  • es6实现深拷贝的方法是什么
    ES6实现深拷贝的方法有多种,以下是其中一种常用的方法:1. 使用`JSON.parse()`和`JSON.stringify()`...
    99+
    2023-10-09
    es6
  • 前端面试的底气之实现一个深拷贝
    目录前言青铜段位白银段位黄金段位铂金段位砖石段位星耀段位王者段位总结前言 深拷贝这个功能在开发中经常使用到,特别在对引用类型的数据进行操作时,一般会先深拷贝一份赋值给一个变量,然后在...
    99+
    2024-04-02
  • JavaScript深拷贝方法structuredClone如何使用
    本篇内容主要讲解“JavaScript深拷贝方法structuredClone如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript深拷贝方法structuredClone如...
    99+
    2023-07-05
  • js中对象深拷贝方法总结
    快速克隆(存在数据丢失问题) – JSON.parse/stringify 如果不在对象中使用Date、functions、undefined、Infinity、RegE...
    99+
    2022-11-13
    js对象深拷贝方法 js对象快速克隆 js原生实现对象深拷贝方法
  • PHP拷贝图像的一部分
    这篇文章将为大家详细讲解有关PHP拷贝图像的一部分,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。图像裁切与复制 前言 图像裁切是指从现有图像中提取特定区域的过程,而图像复制是指创建图像原始副本。在 PHP...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作