力扣刷题笔记 696. 计数二进制子串 C#

今日签到题,题目如下:

给你无向 连通 图中一个节点的引用,请你返回该图的 深拷贝(克隆)。

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

class Node {
    public int val;
    public List 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());
        return cloneNode;
    }

    public Node CloneNode(Node baseNode,Dictionary cloneDict)
    {
        if (cloneDict.ContainsKey(baseNode)) return cloneDict[baseNode];
        Node ret = new Node(baseNode.val, new List());
        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。

你可能感兴趣的:(基础算法)