当前位置: 首页 > news >正文

BFS 求解 最小高度树 【妙用】

310. 最小高度树

链接 :题目链接

  • 思路
    • 常规解法是树形dp,两个dfs解决,这里不再赘述
    • 新颖解法bfs,而且实现更加简单,大体思路就是每次都从叶子节点一步步往中心爬,最后一批留在队列中的节点就为本题意的答案,具体实现思路就是每次更新叶子节点,也就是把之前的叶子节点扔掉,然后和它相连的节点度数减一产生新的叶子节点。

代码


class Solution {
public:vector<int> findMinHeightTrees(int n, vector<vector<int>>& edges) {if(n == 1) return {0};vector<int> out(n+10);// 统计每个点的出度vector<vector<int>> e(n+10);for(auto i : edges){int a = i[0];int b = i[1];out[a] ++, out[b] ++;e[b].push_back(a);// 建立邻接表e[a].push_back(b);}vector<int> res;queue<int> q;for(int i = 0; i < n; i ++){if(out[i] == 1)// 先让出度为1的点入队{q.push(i);}}while(q.size()){res.clear();// res 存储当下遍历完的节点int num = q.size();for(int i = 0; i < num; i ++){int x = q.front();q.pop();res.push_back(x);for(auto it : e[x]){out[it] --;// 与该点连接的点 出度减一if(out[it] == 1)// 添加新的"叶子节点"{q.push(it);}}}}return res;}
};

思路来自 大佬小鑫

http://www.lryc.cn/news/319593.html

相关文章:

  • 【机器学习300问】36、什么是集成学习?
  • Stargo 管理部署 Starrocks 集群
  • CI/CD实战-git工具使用 1
  • Linux中udp服务端,客户端的开发
  • 1.python安装
  • 【Flink SQL】Flink SQL 基础概念(三):SQL 动态表 连续查询
  • 科研绘图一:箱线图(添加贝赛尔曲线)
  • 最佳实践:Swagger 自动生成 Api 文档
  • 搬砖。。。
  • 【论文笔记合集】Transformers in Time Series A Survey综述总结
  • HarmonyOS(二十)——管理应用拥有的状态之LocalStorage(页面级UI状态存储)
  • Linux系统安全②SNAT与DNAT
  • 【运维】StarRocks数据迁移到新集群(针对于集群互通、不互通的情况)
  • facebook个人广告账户充值方式有哪些?看这一篇就够了
  • 蓝桥杯算法练习系统—作物杂交【第十一届】【省赛】【C组】
  • java组合模式揭秘:如何构建可扩展的树形结构
  • pycharm 历史版本下载地址
  • Day39:安全开发-JavaEE应用SpringBoot框架Actuator监控泄漏Swagger自动化
  • VsCode免密登录
  • 蓝桥杯第八届A组:分巧克力
  • 前端框架的发展史介绍框架特点
  • 【MatLab】之:Simulink安装
  • 动手学习深度学习之环境配置
  • 【机器学习300问】35、什么是随机森林?
  • 用云服务器构建gpt和stable-diffusion大模型
  • 备考2024年小学生古诗文大会:历年真题15题练习和独家解析
  • C++之模板
  • Ubuntu Flask 运行 gunicorn+Nginx 部署
  • Tuxera NTFS 2023安装使用教程 Tuxera NTFS破解版 Tuxera NTFS for Mac优惠
  • Linux-centos如何搭建yum源仓库