leetcode@ [310] Minimum Height Trees
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:
Given n = 4, edges = [[1, 0], [1, 2], [1, 3]]
0
|
1
/ \
2 3
return [1]
Example 2:
Given n = 6, edges = [[0, 3], [1, 3], [2, 3], [4, 3], [5, 4]]
0 1 2
\ | /
3
|
4
|
5
return [3, 4]
Hint:
- How many MHTs can a graph have at most?
Note:
(1) 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.”
(2) The height of a rooted tree is the number of edges on the longest downward path between the root and a leaf.
public class Solution {
/** return the height of tree if let s to be the root of the tree */
public static int bfs(ArrayList<ArrayList<Integer> > g, int s) {
HashSet<Integer> upper = new HashSet<Integer> ();
HashSet<Integer> lower = new HashSet<Integer> ();
HashSet<Integer> vis = new HashSet<Integer> ();
upper.add(s);
vis.add(s);
int lv = 1;
while(!upper.isEmpty()) {
for(int u: upper) {
ArrayList<Integer> adj = g.get(u);
for(int i=0; i<adj.size(); ++i) {
int adj_node = adj.get(i);
if(!vis.contains(adj_node)) {
lower.add(adj_node);
}
}
}
if(!lower.isEmpty()) {
++lv;
}
upper.clear();
for(int c: lower) {
vis.add(c);
upper.add(c);
}
lower.clear();
}
return lv;
}
public static ArrayList<Integer> topologicalSort(int n, int[][] edges, ArrayList<ArrayList<Integer> > g) {
ArrayList<Integer> topo = new ArrayList<Integer> ();
int[] d = new int[n];
for(int i=0; i<edges.length; ++i) {
int u = edges[i][0], v = edges[i][1];
++d[u]; ++d[v];
}
LinkedList<Integer> queue = new LinkedList<Integer> ();
for(int i=0; i<n; ++i) {
if(d[i] == 1) {
queue.addLast(i);
}
}
while(!queue.isEmpty()) {
int top = queue.pollFirst();
topo.add(top);
ArrayList<Integer> adj = g.get(top);
for(int next: adj) {
d[next]--;
if(d[next] == 1) {
queue.addLast(next);
}
}
}
return topo;
}
public List<Integer> findMinHeightTrees(int n, int[][] edges) {
List<Integer> rs = new ArrayList<Integer> ();
if(n == 1) {
rs.add(0);
return rs;
}
ArrayList<ArrayList<Integer> > g = new ArrayList<ArrayList<Integer> > ();
for(int i=0; i<n; ++i) {
ArrayList<Integer> row = new ArrayList<Integer> ();
g.add(row);
}
for(int i=0; i<edges.length; ++i) {
int u = edges[i][0];
int v = edges[i][1];
g.get(u).add(v);
g.get(v).add(u);
}
HashMap<Integer, Integer> mapping = new HashMap<Integer, Integer> ();
ArrayList<Integer> topo = topologicalSort(n, edges, g);
int idx = topo.get(topo.size()-1);
int min_lv = bfs(g, idx);
rs.add(idx);
if(topo.size() >= 2) {
int indice = topo.get(topo.size()-2);
if(bfs(g, indice) == min_lv) {
rs.add(indice);
}
}
return rs;
}
}
leetcode@ [310] Minimum Height Trees的更多相关文章
- [LeetCode] 310. Minimum Height Trees 解题思路
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- [LeetCode] 310. Minimum Height Trees 最小高度树
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- 【LeetCode】310. Minimum Height Trees 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 BFS 相似题目 参考资料 日期 题目地址:http ...
- 310. Minimum Height Trees
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- [LeetCode] 310. Minimum Height Trees_Medium tag: BFS
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- 310. Minimum Height Trees -- 找出无向图中以哪些节点为根,树的深度最小
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- [LeetCode] Minimum Height Trees 最小高度树
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- LeetCode Minimum Height Trees
原题链接在这里:https://leetcode.com/problems/minimum-height-trees/ 题目: For a undirected graph with tree cha ...
- Minimum Height Trees -- LeetCode
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
随机推荐
- 52. N-Queens II
题目: Follow up for N-Queens problem. Now, instead outputting board configurations, return the total n ...
- OSSEC 安装执行./install.sh详细信息
下载好ossec安装文件后解压得到如下目录 [root@localhost ~]# cd ossec-hids-/ [root@localhost ossec-hids-]# ll total drw ...
- Android LayoutInflater.inflate()的参数及其用法
很多人在网上问LayoutInflater类的用法,以及inflate()方法参数的含义,现解释如下: inflate()的作用就是将一个用xml定义的布局文件查找出来,注意与findViewById ...
- eclipse Juno Indigo Helios Galileo这几种版本的意思(转)
Galileo Ganymede Europa 这些名字代表eclipse不同的版本 2001年11月7日 ,Eclipse 1.0发布 半年之后,2002年6月27日Eclipse进入了2.0 ...
- win7进入不了系统故障修复
问题: 由于电脑关机比较慢,等得不耐烦了,就强制关机了,以前都没事,直到昨晚打开电脑,提示windows错误恢复,试了好久,提示windows无法修复此计算机,看来是没办法了.后来进入系统还原后,总算 ...
- decode-string(挺麻烦的)
Java String作为参数传参是不会改变的,这个与常识的感觉不同. public String decodeString(String s) { s = ""; return ...
- Codeforces 383A - Milking cows
原题地址:http://codeforces.com/problemset/problem/383/A 题目大意:有 n 头奶牛,全部看着左边或者右边,现在开始给奶牛挤奶,给一头奶牛挤奶时,所有能看到 ...
- rsync不存在用户处理CPU消耗拒绝服务漏洞
受影响产品: rsync 3.1.0 漏洞描述: CVE ID:CVE-2014-2855 rsync是一款文件同步管理软件. rsync处理不存在用户时存在安全漏洞,可消耗大量CPU资源,造成拒绝服 ...
- BZOJ3681: Arietta
题解: 数据结构来优化网络流,貌似都是用一段区间来表示一个点,然后各种乱搞... 发现主席树好吊...在树上建主席树貌似有三种方法: 1.建每个点到根节点这条链上的主席树,可以回答和两点间的路径的XX ...
- 极光推送使用实例(二) Android客户端
上一篇简单介绍了极光推送在Java服务端的实现,如果感兴趣的可以看一下极光推送使用实例(一)JAVA服务端.这篇文章介绍下极光推送在Android客户端的实现. JPush Android SDK 是 ...