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

河源东莞网站建设长沙百度推广排名

河源东莞网站建设,长沙百度推广排名,wordpress同步微信,wordpress文章自定义css题目链接 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.shuangfujiaoyu.com/news/35865.html

相关文章:

  • 公司宣传网站怎么做上海高玩seo
  • 自己开一个网站怎么赚钱郑州专业seo推荐
  • 网站建设微信商城开发网络销售真恶心
  • 取消wordpress 黑标题seo文章外包
  • 设计手机商城网站建设网站快速搜索
  • 网站建设分几步百度指数电脑端查询
  • 网站建设 中国移动引擎优化seo
  • 耒阳做网站互动营销的案例及分析
  • 广西 网站建设品牌策划方案怎么做
  • 两学一做 答题 网站深圳seo论坛
  • 订牛奶网站怎么做认识网络营销
  • 猪八戒做网站 纠纷关键词简谱
  • 电商网站建设培训淘宝补流量平台
  • 设计之窗网站网络推广怎么做?
  • 中国建设网站银行百度公司官网招聘
  • 西安做网站公司工资百度竞价点击价格公式
  • 电商平台项目运营策划方案沈阳seo公司
  • 做网站低价线上营销的方式
  • 网站的首页面设计网络营销的主要方式
  • mg网站建设教程网站建设制作专业
  • 自助旅游网站开发分析报告优化二十条
  • discuz 门户网站模板怎么在网络上推广
  • 做博彩类网站费用关键词搜索引擎优化推广
  • 通河县机场建设网站品牌设计公司排名前十强
  • 中企动力网站建设 医疗公司网站搭建
  • 大淘客网站商品做淘口令seo网站快排
  • 最全网站源码分享疫情最新消息今天封城了
  • 网站开发语言数据库有几种杭州排名优化公司
  • 中国网站优化公司站长工具查询入口
  • dz wordpressseo公司哪家好