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

133. Clone Graph

时间:2016-05-23 06:48:11      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:

    /*
     * 133. Clone Graph
     * 12.19 by Mingyang
     * 第一种方法就是我们用的那种BFS的方法,queue进行广度遍历
     * 不要忘了新建neighbor的点后要注意把关系也copy过来
     * 第二种方法就是DFS的方法,也就是stack来做深度遍历,换汤不换药
     * 无论怎么换,记住,用map比较好,可以记住两个node之间的对应关系
     */
    public UndirectedGraphNode cloneGraph(UndirectedGraphNode root) {
        if (root == null)
            return null;
        Map<UndirectedGraphNode, UndirectedGraphNode> map = new HashMap<UndirectedGraphNode, UndirectedGraphNode>();
        Queue<UndirectedGraphNode> queue = new LinkedList<UndirectedGraphNode>();
        queue.add(root);
        map.put(root, new UndirectedGraphNode(root.label));
        while (!queue.isEmpty()) {
            UndirectedGraphNode node = queue.poll();
            // handle the neighbors
            for (UndirectedGraphNode neighbor : node.neighbors) {
                if (!map.containsKey(neighbor)) {
                    map.put(neighbor, new UndirectedGraphNode(neighbor.label)); // 这就是一个映射的影子,对于每一个元素,在地图中注册下你的影子
                    queue.add(neighbor);
                }
                // copy the neighbor
                map.get(node).neighbors.add(map.get(neighbor)); // 当注册好影子以后,我们需要把原图中的关系也copy过来
            }
        }

        return map.get(root);
    }
    // 用非递归的DFS来做,也就是用Stack
    public UndirectedGraphNode cloneGraph2(UndirectedGraphNode root) {
        if (root == null)
            return null;
        HashMap<UndirectedGraphNode, UndirectedGraphNode> map = new HashMap<UndirectedGraphNode, UndirectedGraphNode>();
        LinkedList<UndirectedGraphNode> stack = new LinkedList<UndirectedGraphNode>();
        UndirectedGraphNode head = new UndirectedGraphNode(root.label);
        map.put(root, head);
        stack.push(root);
        while (!stack.isEmpty()) {
            UndirectedGraphNode node = stack.pop();
            for (UndirectedGraphNode neighbor : node.neighbors) {
                if (!map.containsKey(neighbor)) {    
                    map.put(neighbor, new UndirectedGraphNode(neighbor.label));
                    stack.push(neighbor);
                }
                map.get(node).neighbors.add(map.get(neighbor));
            }
        }
        return head;
    }    
    //用递归的DFS
    public UndirectedGraphNode cloneGraph3(UndirectedGraphNode node) {
        if(node == null)
            return null;       
        HashMap<UndirectedGraphNode, UndirectedGraphNode> map = new HashMap<UndirectedGraphNode, UndirectedGraphNode>();
        UndirectedGraphNode head = new UndirectedGraphNode(node.label);
        map.put(node, new UndirectedGraphNode(node.label));   
        dfs(map, node);//DFS
        return head;
    }
    public void dfs(HashMap<UndirectedGraphNode, UndirectedGraphNode> map, UndirectedGraphNode node){
        if(node == null)
            return;          
        for(UndirectedGraphNode neighbor: node.neighbors){ 
            if(!map.containsKey(neighbor)){
                map.put(neighbor,  new UndirectedGraphNode(neighbor.label));
                dfs(map, neighbor);//DFS
            }
            map.get(node).neighbors.add(map.get(neighbor));
        }
    }

 

133. Clone Graph

标签:

原文地址:http://www.cnblogs.com/zmyvszk/p/5518588.html

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