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

310. Minimum Height Trees

时间:2018-11-06 11:09:40      阅读:116      评论:0      收藏:0      [点我收藏+]

标签:res   share   and   output   ted   poll   leave   des   empty   

https://leetcode.com/problems/minimum-height-trees/discuss/76055/Share-some-thoughts


For a undirected graph with tree characteristics, we can choose any node as the root. The result graph is then a rooted tree. Among all possible rooted trees, those with minimum height are called minimum height trees (MHTs). Given such a graph, write a function to find all the MHTs and return a list of their root labels.
Format?The graph contains n nodes which are labeled from 0 to n - 1. You will be given the number n and a list of undirected edges(each edge is a pair of labels).
You can assume that no duplicate edges will appear in edges. Since all edges are undirected, [0, 1] is the same as [1, 0] and thus will not appear together in edges.
Example 1 :
Input: n = 4, edges = [[1, 0], [1, 2], [1, 3]]

        0
        |
        1
       /      2   3 

Output: [1]
Example 2 :
Input: n = 6, edges = [[0, 3], [1, 3], [2, 3], [4, 3], [5, 4]]

     0  1  2
      \ | /
        3
        |
        4
        |
        5 

Output: [3, 4]
Note:
* According to the definition of tree on Wikipedia: “a tree is an undirected graph in which any two vertices are connected by exactly one path. In other words, any connected graph without simple cycles is a tree.”
* The height of a rooted tree is the number of edges on the longest downward path between the root and a leaf.








// correct, other’s code

Basically my code starts from the leaf nodes.

For leaf nodes, their degree = 1, which means each of them is only connected to one node.

In our loop, each time we delete the leaf nodes from our graph(just by putting their degrees to 0), and meanwhile we add the new leaf nodes after deleting them(just add their connected nodes with degree as 2) to the queue.

So basically in the end, the nodes in the queue would be connected to no other nodes but each other. They should be the answer.

List<List<Integer>> myGraph = new ArrayList<List<Integer>>();
    List<Integer> res = new ArrayList<Integer>();
    if (n==1) {
        res.add(0);
        return res;
    }
    int[] degree = new int[n];
    for(int i=0; i<n; i++) {
        myGraph.add(new ArrayList<Integer>());
    }
    for(int i=0; i<edges.length; i++) {
        myGraph.get(edges[i][0]).add(edges[i][1]);
        myGraph.get(edges[i][1]).add(edges[i][0]);
        degree[edges[i][0]]++;
        degree[edges[i][1]]++;
    }
    Queue<Integer> myQueue = new ArrayDeque<Integer>();
    
    for(int i=0; i<n; i++) 
        if (degree[i]==0) 
            return res;
        else if (degree[i]==1) {
            myQueue.offer(i);
        }
    
    while (!myQueue.isEmpty()) {
        res = new ArrayList<Integer>();
        int count = myQueue.size();
        
        for(int i=0; i<count; i++){
            int curr = myQueue.poll();
            res.add(curr);
            degree[curr]--;
            for(int k=0; k<myGraph.get(curr).size(); k++) {
                int next = myGraph.get(curr).get(k);
                if (degree[next]==0) continue;
                if (degree[next]==2) {
                    myQueue.offer(next);
                }
                degree[next]--;
            }
        }          
    }
    return res;










// wrong , out of bound ?? 
class Solution {
    public List<Integer> findMinHeightTrees(int n, int[][] edges) {
        // in this example , leaf node has indgree 1, since the tree is not directed 
        // we do topological order , starting from all the leaf nodes , when there is only one or two 
        // nodes left , then we know we‘ve reached the center, which is the root nodes of the minimum hieght tree 
        
        // steps : build graph , and then do bfs topo sort 
        // use list, assumpe there is no duplicate edge input 
        List<List<Integer>> adjList = new ArrayList<>();
        for(int i = 0; i < adjList.size() - 1; i++){
            adjList.add(new ArrayList<>());
        }
        for(int[] edge : edges){
            adjList.get(edge[0]).add(edge[1]);
            adjList.get(edge[1]).add(edge[0]);
        }
        List<Integer> leaves = new ArrayList<>();
        
        // get all the leaves 
        for(int i = 0; i < adjList.size() - 1; i++){
            if(adjList.get(i).size() == 1){
                leaves.add(i);
            }
        }
        
        while(n > 2){
            n -= leaves.size();
            List<Integer> newLeaves = new ArrayList<>();
            for(int leaf : leaves){
                for(int nei : adjList.get(leaf)){
                    adjList.get(nei).remove(leaf);
                    if(adjList.get(nei).size() == 1){
                        newLeaves.add(nei);
                    }
                }
            }
            leaves = newLeaves;
        }
        return leaves;
    }
}

 

310. Minimum Height Trees

标签:res   share   and   output   ted   poll   leave   des   empty   

原文地址:https://www.cnblogs.com/tobeabetterpig/p/9913174.html

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