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

0基础学习网站建设高端网站建设推广

0基础学习网站建设,高端网站建设推广,没有公司 接单做网站,百度网站官网入口网址题目链接 Leetcode.2359 找到离给定两个节点最近的节点 Rating : 1715 题目描述 给你一个 n个节点的 有向图 ,节点编号为 0到 n - 1,每个节点 至多 有一条出边。 有向图用大小为 n下标从 0开始的数组 edges表示,表示节点 i有一条…

题目链接

Leetcode.2359 找到离给定两个节点最近的节点 Rating : 1715

题目描述

给你一个 n个节点的 有向图 ,节点编号为 0n - 1,每个节点 至多 有一条出边。

有向图用大小为 n下标从 0开始的数组 edges表示,表示节点 i有一条有向边指向 edges[i]。如果节点 i没有出边,那么 edges[i] == -1

同时给你两个节点 node1node2

请你返回一个从 node1node2都能到达节点的编号,使节点 node1和节点 node2到这个节点的距离 较大值最小化。如果有多个答案,请返回 最小 的节点编号。如果答案不存在,返回 -1

注意 edges可能包含环。

示例1:

在这里插入图片描述

输入:edges = [2,2,3,-1], node1 = 0, node2 = 1
输出:2
解释:从节点 0 到节点 2 的距离为 1 ,从节点 1 到节点 2 的距离为 1 。
两个距离的较大值为 1 。我们无法得到一个比 1 更小的较大值,所以我们返回节点 2 。

示例2:

在这里插入图片描述

输入:edges = [1,2,-1], node1 = 0, node2 = 2
输出:2
解释:节点 0 到节点 2 的距离为 2 ,节点 2 到它自己的距离为 0 。
两个距离的较大值为 2 。我们无法得到一个比 2 更小的较大值,所以我们返回节点 2 。

提示:

  • n==edges.lengthn == edges.lengthn==edges.length
  • 2<=n<=1052 <= n <= 10^52<=n<=105
  • −1<=edges[i]<n-1 <= edges[i] < n1<=edges[i]<n
  • edges[i]!=iedges[i] != iedges[i]!=i
  • 0<=node1,node2<n0 <= node1, node2 < n0<=node1,node2<n

解法一:BFS

一个比较容易想到的解法是,对于 node1node2分别通过 BFS 计算其 到各个点的距离矩阵 d1d2

对于 d1d2,我们从小到大遍历,更新最小的 较大值。

时间复杂度:O(n)O(n)O(n)

代码:

class Solution {
public:
// 建图unordered_map<int,vector<int>> g;//bfs 求起点 root 到各个点的距离矩阵void bfs(int root,vector<int> & dist){queue<int> q;q.push(root);int step = 0;while(!q.empty()){int sz = q.size();for(int i = 0;i < sz;i++){auto t = q.front();q.pop();dist[t] = step;for(auto v:g[t]){if(dist[v] != -1) continue;q.push(v);}}step++;}}int closestMeetingNode(vector<int>& edges, int node1, int node2) {int n = edges.size();for(int i = 0;i < n;i++){if(edges[i] == -1) continue;int a = i, b = edges[i];g[a].push_back(b);}vector<int> a(n,-1),b(n,-1);bfs(node1,a);bfs(node2,b);/*for(int i = 0;i < n;i++){printf("i = %d , d1 = %d , d2 = %d\n",i,a[i],b[i]);}*/int dist = 1e9;int idx = -1;for(int i = 0;i < n;i++){if(a[i] == -1 || b[i] == -1) continue;int d = max(a[i],b[i]);if(dist > d){dist = d;idx = i;}}return idx;}
};

解法二:遍历

题目给定地有向图实际上是一个 基环树,因为每一个结点的 出边最多只有一条,所以实际上我们不需要建图,只需要直接循环遍历即可。

时间复杂度:O(n)O(n)O(n)

代码:

class Solution {
public:int closestMeetingNode(vector<int>& edges, int node1, int node2) {int n = edges.size();auto dfs = [&](int u) -> vector<int>{vector<int> dist(n,1e9);int d = 0;while(u != -1 && dist[u] == 1e9){dist[u] = d;d++;u = edges[u];}return dist;};auto d1 = dfs(node1);auto d2 = dfs(node2);int ans = 1e9,idx = -1;for(int i = 0;i < n;i++){if(d1[i] == 1e9 || d2[i] == 1e9) continue;int d = max(d1[i],d2[i]);if(ans > d){ans = d;idx = i;}}return idx;}
};
http://www.yayakq.cn/news/670184/

相关文章:

  • 网站返利二维码怎么做小程序登录不上去一般是什么原因
  • 河南省住房和城乡建设门户网站怎么做动态的实时更新的网站
  • 免费网站建设无广告国家建设部网站查询
  • 免费网站正能量小说网站推荐你了解我意思吧
  • 如果建设网站门户网站盈利模式
  • 江苏营销型网站建设网站建设优化兼职在家
  • 哪个网站做网上旅社预定wordpress图片处理类
  • 建设网站费用计入什么费用做网站530元
  • 做防水施工 上什么网站找怎么把网站做的更好
  • 哈尔滨建设部网站有什么可以做翻译的网站
  • 长沙装饰公司长沙优化官网公司
  • 漯河网站建设哪家wordpress 页面缓存
  • 高端网站搭建wordpress修改默认头像
  • 无锡网站排名公司快速网站优化技巧
  • 暴雪游戏官网建站优化推广
  • 那个网站开发三味怎样自己做免费的网站
  • 企业网站建设的公司做非洲出口的网站
  • 网站制作好吗适合机械网站的wordpress主题模板
  • 如何在导航网站上做链接百度互联网营销
  • 凡科网站建站后 怎么编辑自己的代码源南京比较大的外贸公司有哪些
  • t和p在一起怎么做网站微信开发品牌
  • 济南伍际网站建设太原模板建站系统
  • 濮阳市网站怎么做宣传网络项目
  • 用媒体做响应式网站可以吗易支付做网站接口怎么赚钱
  • 备案 网站下线wordpress如何关注博客
  • 上海注册公司核名网站企业注册资本
  • 网站资讯板块的搭建网站 转成 微信小程序
  • 网站建设电脑如何建设网站服务器
  • 网站制作洋网络wordpress仿落网
  • 南充网站建设天赐建一个网站需要什么