对于一个具有树特征的无向图,我们可选择任何一个节点作为根。图因此可以成为树,在所有可能的树中,具有最小高度的树被称为最小高度树。给出这样的一个图,写出一个函数找到所有的最小高度树并返回他们的根节点。

格式

该图包含 n 个节点,标记为 0 到 n - 1。给定数字 n 和一个无向边 edges 列表(每一个边都是一对标签)。

你可以假设没有重复的边会出现在 edges 中。由于所有的边都是无向边, [0, 1]和 [1, 0] 是相同的,因此不会同时出现在 edges 里。

示例 1:

输入: n = 4, edges = [[1, 0], [1, 2], [1, 3]]

0
|
1
/ \
2 3

输出: [1]
示例 2:

输入: n = 6, edges = [[0, 3], [1, 3], [2, 3], [4, 3], [5, 4]]

0 1 2
\ | /
3
|
4
|
5

输出: [3, 4]
说明:

根据树的定义,树是一个无向图,其中任何两个顶点只通过一条路径连接。 换句话说,一个任何没有简单环路的连通图都是一棵树。
树的高度是指根节点和叶子节点之间最长向下路径上边的数量。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-height-trees
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

第一次尝试是用深度优先算法去计算每个点作为根时的高度,然后再找出最小值,结果时间复杂度太大。(我也想不清楚这个时间复杂度有多大,该怎么算)

第二次发现可以多次去除叶子结点,即度数为1的点。当一次去除之后发现所有的点都被去除时,这次去除的点就是答案。不过在每次去除时要注意不能同时判断同时去除,那样会导致再删除的过程中会有次叶子结点变成叶子结点在同一轮被删除。应当先记录哪些点需要去除再统一地进行去除和删边。

class Solution {
public:
int visited[],deg[];
/* int dfs(int t,int heigh, vector<vector<int>>& edges){
int max=-1,o,i;
for(i=0;i<edges.size();i++){
if(edges[i][0]==t&&visited[edges[i][1]]==0){
visited[edges[i][1]]=1;
o=dfs(edges[i][1],heigh+1,edges);
if(o>max) max=o;
visited[edges[i][1]]=0;
}else if(edges[i][1]==t&&visited[edges[i][0]]==0){
visited[edges[i][0]]=1;
o=dfs(edges[i][0],heigh+1,edges);
if(o>max) max=o;
visited[edges[i][0]]=0;
}
}
if(max==-1){
return heigh;
}
return max;
}
int height(int k,int n, vector<vector<int>>& edges){ for(i=0;i<n;i++){
visited[i]=0;
} }*/
/*vector<int> findMinHeightTrees(int n, vector<vector<int>>& edges) {
int i,ii;
for(i=0;i<n;i++){
visited[i]=0;
}
vector<int> res;
int r,min=10000000;
for(i=0;i<n;i++){
visited[i]=1;
r=dfs(i,0,edges);
if(r<min){
res.clear();
res.push_back(i);
min=r;
}else if(r==min){
res.push_back(i);
}
//cout<<i<<" "<<r<<endl;
visited[i]=0;
}
return res;
}*/
vector<int> findMinHeightTrees(int n, vector<vector<int>>& edges) {
int i;
int live[n];
for(i=;i<n;i++){
deg[i]=;
live[i]=;
}
for(i=;i<edges.size();i++){
deg[edges[i][]]++;
deg[edges[i][]]++;
}
vector<int> res;
int t=,j,z=n;
while(z>){
res.clear();
for(i=;i<n;i++){
if(deg[i]<=t&&live[i]==){
res.push_back(i);
}
}
for(i=;i<res.size();i++){
for(j=;j<edges.size();j++){
if(edges[j][]==res[i]&&live[edges[j][]]==){
deg[edges[j][]]--;
}
if(edges[j][]==res[i]&&live[edges[j][]]==){
deg[edges[j][]]--;
}
}
z--;
live[res[i]]=;
//cout<<"t="<<t<<" "<<i<<" is moved\n";
}
}
return res;
}
};

leetcode.310最小高度树的更多相关文章

  1. Java实现 LeetCode 310 最小高度树

    310. 最小高度树 对于一个具有树特征的无向图,我们可选择任何一个节点作为根.图因此可以成为树,在所有可能的树中,具有最小高度的树被称为最小高度树.给出这样的一个图,写出一个函数找到所有的最小高度树 ...

  2. Leetcode 310.最小高度树

    最小高度树 对于一个具有树特征的无向图,我们可选择任何一个节点作为根.图因此可以成为树,在所有可能的树中,具有最小高度的树被称为最小高度树.给出这样的一个图,写出一个函数找到所有的最小高度树并返回他们 ...

  3. [LeetCode] Minimum Height Trees 最小高度树

    For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...

  4. [Swift]LeetCode310. 最小高度树 | Minimum Height Trees

    For an undirected graph with tree characteristics, we can choose any node as the root. The result gr ...

  5. 最小高度树Java版本(力扣)

    最小高度树 给定一个有序整数数组,元素各不相同且按升序排列,编写一个算法,创建一棵高度最小的二叉搜索树. 示例:给定有序数组: [-10,-3,0,5,9],一个可能的答案是:[0,-3,9,-10, ...

  6. [LeetCode] 310. Minimum Height Trees 最小高度树

    For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...

  7. 最小高度的树 Minimum Height Trees

    2018-09-24 12:01:38 问题描述: 问题求解: 毫无疑问的一条非常好的题目,采用的解法是逆向的BFS,也就是从叶子节点开始遍历,逐步向中心靠拢,最终留下的叶子节点就是答案. publi ...

  8. [LeetCode] 310. Minimum Height Trees 解题思路

    For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...

  9. 九度oj 题目1536:树的最小高度

    题目描述: 给定一棵无向树, 我们选择不同的节点作为根节点时,可以得到不同的高度(即树根节点到叶子节点距离的最大值), 现在求这棵树可能的最低高度. 输入: 输入可能包含多个测试案例. 对于每个测试案 ...

随机推荐

  1. DTCC 2019 | 深度解码阿里数据库实现 数据库内核——基于HLC的分布式事务实现深度剖析

    摘要:分布式事务是分布式数据库最难攻克的技术之一,分布式事务为分布式数据库提供一致性数据访问的支持,保证全局读写原子性和隔离性,提供一体化分布式数据库的用户体验.本文主要分享分布式数据库中的时钟解决方 ...

  2. Android图形子系统

    图形操作可以有两种方式实现:一是利用通用CPU模拟图形操作:二是利用GPU专门做图形操作.前者会增加CPU的负担,在现在高分辨率已经是普遍现象的时候,让通用处理器来完成大量的图形计算已经不现实.And ...

  3. Android教程-03 常见布局的总结

    常见的布局 视频建议采用超清模式观看, 欢迎点击订阅我的优酷 Android的图形用户界面是由多个View和ViewGroup构建出来的.View是通用的UI窗体小组件,比如按钮(Button)或者文 ...

  4. 前端开发之BOM和DOM(转载)

    BOM BOM:是指浏览器对象模型,它使JavaScript可以和浏览器进行交互. 1,navigator对象:浏览器对象,通过这个对象可以判定用户所使用的浏览器,包含了浏览器相关信息. naviga ...

  5. Linux查看用户及其权限管理

    https://www.cnblogs.com/fxlttkl/p/7601224.html 查看用户 请打开终端,输入命令: $ who am i 或者 $ who mom likes 输出的第一列 ...

  6. 在 CentOS 7.3 上安装 nginx 服务为例,说明在 Linux 实例中如何检查 TCP 80 端口是否正常工作

    CentOS 7.3 这部分以在 CentOS 7.3 上安装 nginx 服务为例,说明在 Linux 实例中如何检查 TCP 80 端口是否正常工作. 登录 ECS 管理控制台,确认实例所在安全组 ...

  7. Element节点输出到System.out

    protected void writeElementToFile(Element valrespEle) { try { TransformerFactory transformerFactory ...

  8. 通过页码直接跳转 html

    <?php namespace Admin\TagLib; class BootstrapPage{ public $firstRow; // 起始行数 public $listRows; // ...

  9. es6 let和const的用法

    ]()) {; } //console.log(MAX);//MAX is not defined" /*也有暂时性死区,声明的位置需要在使用前面,否则报错: * 不能重复声明变量 * */ ...

  10. ajaxSetup()方法

    使用ajaxSetup()方法设置全局Ajax默认选项 使用ajaxSetup()方法可以设置Ajax请求的一些全局性选项值,设置完成后,后面的Ajax请求将不需要再添加这些选项值,它的调用格式为: ...