码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 133: Clone Graph

时间:2017-08-22 15:55:07      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:off   create   solution   cti   class   contain   link   style   ons   

/**
 * 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

标签:off   create   solution   cti   class   contain   link   style   ons   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!