克隆图——java实现

题目

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

思路

深拷贝的核心是new一个新的节点出来,为其分配空间,而不仅仅是赋值
用hashmap记录原node 和 新node的对应关系。若原node已经作为key存在于hashmap里,那么说明它的拷贝(新node)也已经存在,直接获得它的拷贝,否则,就要为这个node生成新的拷贝然后,把拷贝放入hashmap中,并且使得拷贝(新node)的邻接链表添加原node的邻接链表里元素的拷贝。

public class cloneGraph {
 HashMap<Node,Node> visited=new HashMap<>();// 该语句必须放在方法体外,因为方法体内又递归调用,会造成死循环
 public Node cloneGraph(Node node) {
  if(node==null) {
   return null;
  }
  if(visited.containsKey(node)) {      //如果该节点已经访问过,直接获取该节点
   return visited.get(node);
  }else {
   Node newNode=new Node(node.val); //否则,创建新的节点
   visited.put(node, newNode);      //讲该节点标记为已访问
   if(node.neighbors!=null) {       //如果该节点有邻居节点
    for(Node nn:node.neighbors) {//遍历邻居节点
     newNode.neighbors.add(cloneGraph(nn)); //往邻居节点中添加新的邻居
    }
   }
   return newNode;
   }
  }
 }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,可以通过实现 `Cloneable` 接口并重写 `clone()` 方法来实现对象的克隆。 首先,在需要被克隆的类中实现 `Cloneable` 接口,这是一个标记接口,不含任何方法,只是用来指示该类可以被克隆。 然后,重写 `clone()` 方法,该方法返回一个克隆后的对象。在重写过程中,需要调用父类的 `clone()` 方法,并进行类型转换。 下面是一个示例: ```java public class MyClass implements Cloneable { private int value; public MyClass(int value) { this.value = value; } public void setValue(int value) { this.value = value; } public int getValue() { return value; } @Override public Object clone() throws CloneNotSupportedException { return super.clone(); } } ``` 在使用克隆时,可以使用 `clone()` 方法来创建一个原始对象的副本。注意,`clone()` 方法返回的是一个 `Object` 类型的对象,因此需要进行类型转换。 ```java public class Main { public static void main(String[] args) { MyClass obj1 = new MyClass(10); try { MyClass obj2 = (MyClass) obj1.clone(); System.out.println(obj1.getValue()); // 输出 10 System.out.println(obj2.getValue()); // 输出 10 obj2.setValue(20); System.out.println(obj1.getValue()); // 输出 10 System.out.println(obj2.getValue()); // 输出 20 } catch (CloneNotSupportedException e) { e.printStackTrace(); } } } ``` 注意:在使用克隆时,需要注意对象的可变性。如果被克隆的对象包含引用类型的成员变量,需要考虑是否需要进行深拷贝,以避免克隆对象与原始对象共享同一引用,导致意外的修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值