Given a reference of a node in a connected undirected graph. Return a deep copy (clone) of the graph.
Each node in the graph contains a value (int)
and a list(List[Node])
of its neighbors.
Input : Graph 구조로 이루어진 Node
들 중에서 하나의 Node
Ouput : Graph 구조를 deep copy 한 후에, Input으로 제공된 Node의 deep copy를 반환
제공된 코드
class Node {
public int val;
public List<Node> neighbors;
public Node() {
val = 0;
neighbors = new ArrayList<Node>();
}
public Node(int _val) {
val = _val;
neighbors = new ArrayList<Node>();
}
public Node(int _val, ArrayList<Node> _neighbors) {
val = _val;
neighbors = _neighbors;
}
}
기본 전략
연결된 Node 복사 전략
Map<Node, Node> oldToNew
를 이용하여 복사한 Node는 Map에 넣고, 이미 복사된 Node가 있는지 확인할 수 있다.class Solution {
public Node cloneGraph(Node node) {
if (node == null) {
return null;
}
return cloneGraph(node, new HashMap<>());
}
private Node cloneGraph(Node node, Map<Node, Node> oldToNew) {
if (oldToNew.get(node) != null) {
return oldToNew.get(node);
}
Node cloneNode = new Node(node.val);
oldToNew.put(node, cloneNode);
for (Node neighbor : node.neighbors) {
Node cloneNeighbor = oldToNew.getOrDefault(neighbor, cloneGraph(neighbor, oldToNew));
cloneNode.neighbors.add(cloneNeighbor);
}
return cloneNode;
}
}