zoukankan      html  css  js  c++  java
  • 【LeetCode】克隆图

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

    解释:
    节点 1 的值是 1,它有两个邻居:节点 24 。
    节点 2 的值是 2,它有两个邻居:节点 13 。
    节点 3 的值是 3,它有两个邻居:节点 24 。
    节点 4 的值是 4,它有两个邻居:节点 13

    提示:

    • 节点数介于 1 到 100 之间。

    • 无向图是一个简单图,这意味着图中没有重复的边,也没有自环。

    • 由于图是无向的,如果节点 p 是节点 q 的邻居,那么节点 q 也必须是节点 p 的邻居。

    • 必须将给定节点的拷贝作为对克隆图的引用返回。

    【思路】克隆图,并且是无向连通图,因此可以使用map来保存两个节点之间的连接关系,如果在map中没有该节点tmp,则新建节点tmp_copy将该节点存入map中,然后遍历该节点的所有邻居,并递拷贝其所有邻居节点至tmp_copy的邻居数组中。

    /*
    // Definition for a Node.
    class Node {
    public:
        int val;
        vector<Node*> neighbors;
    
        Node() {}
    
        Node(int _val, vector<Node*> _neighbors) {
            val = _val;
            neighbors = _neighbors;
        }
    };
    */
    class Solution {
    public:
        map<Node*,Node*> mp;
        Node* cloneGraph(Node* node) {
            if(!node)   return nullptr;
            if(mp.count(node))  return mp[node];  // 如果存在,就不用新建了
            Node* tmp = new Node(node -> val);
            mp[node] = tmp;
            for(int i = 0; i < node -> neighbors.size(); ++ i){
                if(node -> neighbors[i])    tmp -> neighbors.push_back(cloneGraph(node -> neighbors[i]));
            }
            return tmp;
        }
    };
  • 相关阅读:
    Python操作文件和目录
    ffmpeg命令简单使用
    【转载】一个简单的爬虫:爬取豆瓣的热门电影的信息
    【转载】正则表达式re.S的用法
    linux用户添加
    SQL语句update修改数据库字段
    linux命令之cp
    linux命令——tree命令
    Linux磁盘管理
    Python资源安装过程出现Retrying (Retry(total=4, connect=None, read=None, redirect=None, status=None))…………
  • 原文地址:https://www.cnblogs.com/zhudingtop/p/11596379.html
Copyright © 2011-2022 走看看