首页 > 其他 > 详细

LeetCode 133: Clone Graph

时间:2017-08-22 15:09:51      阅读:158      评论:0      收藏:0      [点我收藏+]
/**
 * Definition for undirected graph.
 * class UndirectedGraphNode {
 *     int label;
 *     List<UndirectedGraphNode> neighbors;
 *     UndirectedGraphNode(int x) { label = x; neighbors = new ArrayList<UndirectedGraphNode>(); }
 * };
 */
public class Solution {
    public UndirectedGraphNode cloneGraph(UndirectedGraphNode node) {
        if (node == null) {
            return null;
        }
        UndirectedGraphNode result = new UndirectedGraphNode(node.label);
        Queue<UndirectedGraphNode> queue = new LinkedList<>();
        Map<UndirectedGraphNode, UndirectedGraphNode> connections = new HashMap<>();
        connections.put(node, result);
        queue.offer(node);
        
        while (!queue.isEmpty()) {
            UndirectedGraphNode current = queue.poll();
            
            for (UndirectedGraphNode neighbor : current.neighbors) {
                if (!connections.containsKey(neighbor)) {
                    UndirectedGraphNode newNode = new UndirectedGraphNode(neighbor.label);
                    connections.put(neighbor, newNode);
                    queue.offer(neighbor);
                }
                connections.get(current).neighbors.add(connections.get(neighbor));
            }
        }
        return result;
    }
}

 

1. Create node when the neighbor is not found.

LeetCode 133: Clone Graph

原文:http://www.cnblogs.com/shuashuashua/p/7411556.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!