【LeetCode刷题】-- 133.克隆图

133.克隆图

本题就是遍历整个图,遍历的时候要记录已经访问过的节点

方法一:深度优先搜索

java 复制代码
/*
// Definition for a Node.
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;
    }
}
*/

class Solution {
    HashMap<Node,Node> visited = new HashMap<>();
    public Node cloneGraph(Node node) {
        if(node == null){
            return node;
        }
        //如果该节点已经被访问过,则直接从哈希表中取出对应的克隆节点返回
        if(visited.containsKey(node)){
            return visited.get(node);
        }
        //克隆节点,注意到为了深拷贝不会克隆他的邻居列表
        Node cloneNode = new Node(node.val,new ArrayList());
        //哈希表存储
        visited.put(node,cloneNode);

        //遍历该节点的邻居并更新克隆节点的邻居列表
        for(Node neighbor : node.neighbors){
            cloneNode.neighbors.add(cloneGraph(neighbor));
        }
        return cloneNode;
        
    }
}

方法二:广度优先搜索

java 复制代码
/*
// Definition for a Node.
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;
    }
}
*/

class Solution {
    public Node cloneGraph(Node node) {
        if(node == null){
            return node;
        }
        HashMap<Node,Node> visited = new HashMap<>();
        //将给定的节点添加到队列
        LinkedList<Node> queue = new LinkedList<Node>();
        queue.add(node);
        //克隆第一个节点并存储到哈希表中
        visited.put(node,new Node(node.val,new ArrayList()));

        //广度优先搜索
        while(!queue.isEmpty()){
            //取出队列的头结点
            Node n = queue.remove();
            //遍历该节点的邻居
            for(Node neighbor : n.neighbors){
                if(!visited.containsKey(neighbor)){
                    //如果没有被访问,就克隆并存储到哈希表
                    visited.put(neighbor,new Node(neighbor.val,new ArrayList()));
                    //将邻居节点添加到队列中
                    queue.add(neighbor);
                }
                //更新当前节点的邻居列表
                visited.get(n).neighbors.add(visited.get(neighbor));
            }
        }
        return visited.get(node);
    }
}
相关推荐
小O的算法实验室13 小时前
2026年IEEE TETCI,山区环境下基于双种群进化的协同无人机巡逻任务协同优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
生成论实验室14 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
风筝在晴天搁浅14 小时前
字节高频题 小于n的最大数
算法
LabVIEW开发14 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星14 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅14 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程15 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
V搜xhliang024615 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师15 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠16 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造