欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 1245. 树的直径(图的最大直径结论)

发布时间:2024/7/5 编程问答 41 豆豆
生活随笔 收集整理的这篇文章主要介绍了 LeetCode 1245. 树的直径(图的最大直径结论) 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

求树的最大直径。

2. 解题

类似题目:LeetCode 5538. 统计子树中城市之间最大距离(枚举所有可能+图的最大直径)

  • 结论:求无权无向图中的最长一条路径
    先从任意一点P出发,找到离它最远的点Q
    再从点Q出发,找离它最远的点W,W到Q的距离就是最长的一条路

  • 采用2次BFS遍历

class Solution { public:int treeDiameter(vector<vector<int>>& edges) {int n = edges.size()+1;unordered_map<int,unordered_map<int,bool>> m;for(auto& e : edges){m[e[0]][e[1]] = 1;m[e[1]][e[0]] = 1;}int a,cur,size,step = 0;queue<int> q;vector<bool> visited(n,false);q.push(0);visited[0] = true;while(!q.empty()){cur = q.front();q.pop();a = cur;//记录最后到达的点afor(auto it = m[cur].begin(); it != m[cur].end(); ++it){if(!visited[it->first]){q.push(it->first);visited[it->first] = true;}}}vector<bool> visited1(n,false);q.push(a);//从a出发,到达的最远的就是最大的路径visited1[a] = true;while(!q.empty()){size = q.size();while(size--){cur = q.front();q.pop();for(auto it = m[cur].begin(); it != m[cur].end(); ++it){if(!visited1[it->first]){q.push(it->first);visited1[it->first] = true;}}}step++;}return step-1;} };

136 ms 24.4 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

创作挑战赛新人创作奖励来咯,坚持创作打卡瓜分现金大奖

总结

以上是生活随笔为你收集整理的LeetCode 1245. 树的直径(图的最大直径结论)的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。