Clone Graph
//BFS
class Solution {
public:
UndirectedGraphNode *cloneGraph(UndirectedGraphNode *node) {
if (!node) return NULL;
UndirectedGraphNode* copy = new UndirectedGraphNode(node -> label);
mp[node] = copy;
queue<UndirectedGraphNode*> toVisit;
toVisit.push(node);
while (!toVisit.empty()) {
UndirectedGraphNode* cur = toVisit.front();
toVisit.pop();
for (UndirectedGraphNode* neigh : cur -> neighbors) {
if (mp.find(neigh) == mp.end()) {
UndirectedGraphNode* neigh_copy = new UndirectedGraphNode(neigh -> label);
mp[neigh] = neigh_copy;
toVisit.push(neigh);
}
mp[cur] -> neighbors.push_back(mp[neigh]);
}
}
return copy;
}
private:
unordered_map<UndirectedGraphNode*, UndirectedGraphNode*> mp;
};
//DFS
class Solution {
public:
unordered_map<UndirectedGraphNode*, UndirectedGraphNode*> hash;
UndirectedGraphNode *cloneGraph(UndirectedGraphNode *node) {
if (!node) return node;
if(hash.find(node) == hash.end()) {
hash[node] = new UndirectedGraphNode(node -> label);
for (auto x : node -> neighbors) {
(hash[node] -> neighbors).push_back( cloneGraph(x) );// 想象走到最后一个点,要clone它然后把它加到所有neighbors的list里面
}
}
return hash[node];
}
};
REF: