今日签到题,题目如下:
给你无向 连通 图中一个节点的引用,请你返回该图的 深拷贝(克隆)。
图中的每个节点都包含它的值 val(int) 和其邻居的列表(list[Node])。
class Node {
public int val;
public List<Node> neighbors;
}
测试用例格式:
简单起见,每个节点的值都和它的索引相同。例如,第一个节点值为 1(val = 1),第二个节点值为 2(val = 2),以此类推。该图在测试用例中使用邻接列表表示。
邻接列表 是用于表示有限图的无序列表的集合。每个列表都描述了图中节点的邻居集。
给定节点将始终是图中的第一个节点(值为 1)。你必须将 给定节点的拷贝 作为对克隆图的引用返回。
提示:
节点数不超过 100 。
每个节点值 Node.val 都是唯一的,1 <= Node.val <= 100。
无向图是一个简单图,这意味着图中没有重复的边,也没有自环。
由于图是无向的,如果节点 p 是节点 q 的邻居,那么节点 q 也必须是节点 p 的邻居。
图是连通图,你可以从给定节点访问到所有节点。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/clone-graph
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
遍历无向连通图所有节点,全都拷贝一遍,深度优先搜索所有节点进行遍历。
唯一需要注意的一点,需要使用一个字典,保存所有已拷贝的节点,避免一个节点的两个邻居多次拷贝同一个节点。字典 key 值为原节点(也可以是节点的 val),value 就是拷贝后的节点。
复杂度分析:
遍历所有节点,时间复杂度为 O(N),
使用一个额外的字典保存所有节点,空间复杂度为 O(N)。
以下为自己提交的代码:
public class Solution {
public Node CloneGraph(Node node) {
if (node == null) return null;
Node cloneNode = CloneNode(node,new Dictionary<Node,Node>());
return cloneNode;
}
public Node CloneNode(Node baseNode,Dictionary<Node,Node> cloneDict)
{
if (cloneDict.ContainsKey(baseNode)) return cloneDict[baseNode];
Node ret = new Node(baseNode.val, new List<Node>());
cloneDict.Add(baseNode,ret);
for (int i = 0; i < baseNode.neighbors.Count; i++)
{
ret.neighbors.Add(CloneNode(baseNode.neighbors[i],cloneDict));
}
return ret;
}
}
顺便回想一下,不知道是同级别的难易度不同,还是真的有进步,一个多月刷了 80 多题力扣感觉解题越来越轻松了,over。