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

怎么把东西发布到网上卖网站seo优化步骤

怎么把东西发布到网上卖,网站seo优化步骤,一般需要多少钱,网络工程是冷门专业吗2316. 统计无向图中无法互相到达点对数 难度: 中等 来源: 每日一题 2023.10.21 给你一个整数 n ,表示一张 无向图 中有 n 个节点,编号为 0 到 n - 1 。同时给你一个二维整数数组 edges ,其中 edges[i] [ai, bi] 表示节点 ai 和 bi 之间…


2316. 统计无向图中无法互相到达点对数
难度: 中等
来源: 每日一题 2023.10.21

给你一个整数 n ,表示一张 无向图 中有 n 个节点,编号为 0n - 1 。同时给你一个二维整数数组 edges ,其中 edges[i] = [ai, bi] 表示节点 aibi 之间有一条 无向 边。

请你返回 无法互相到达 的不同 点对数目

示例 1:

输入:n = 3, edges = [[0,1],[0,2],[1,2]]
输出:0
解释:所有点都能互相到达,意味着没有点对无法互相到达,所以我们返回 0 。

示例 2:

输入:n = 7, edges = [[0,2],[0,5],[2,4],[1,6],[5,4]]
输出:14
解释:总共有 14 个点对互相无法到达:
[[0,1],[0,3],[0,6],[1,2],[1,3],[1,4],[1,5],[2,3],[2,6],[3,4],[3,5],[3,6],[4,6],[5,6]]
所以我们返回 14 。

提示:

  • 1 <= n <= 10^5
  • 0 <= edges.length <= 2 * 10^5
  • edges[i].length == 2
  • 0 <= ai, bi < n
  • ai != bi
  • 不会有重复边。
class StockSpanner {public long countPairs(int n, int[][] edges) {}
}

分析与题解

  • 邻接表 + 深度优先遍历

    这个题目其实就是对无向图的邻接表的理解, 那么求两个点没有任何关联, 我们只要如果只要求出一条完整的边, 那么剩下所有的节点一定与这条完整的边不连接, 不连接的含义就是这条边上的节点与剩下的所有节点都是两两无法相互到达.

    那么基于这样的理论, 我们假设这条边上的节点个数是 m 个, 那么对于这条边上的所有节点与剩下的节点两两无法相互到达的组合个数为 m * (n - m) .

    另外, 假设 节点1节点2 无法相互到达, 那么深度优先遍历 节点1 时,会计算一遍 节点1节点2; 深度优先遍历 节点1 时, 同样会计算一遍 节点1节点2. 所以最终结果我们需要除以2.

    接下来, 我们看一下具体的解题过程.

    首先, 我们先创建无向图的邻接表, 这里我使用的是HashMap来作为邻接表的存储空间.

    // 创建邻接表
    HashMap<Integer, ArrayList<Integer>> cache = new HashMap<>();
    for(int i = 0; i < n; i++) {cache.put(i, new ArrayList<>());
    }
    for(int[] item: edges) {Integer first = item[0];Integer second = item[1];cache.get(first).add(second);cache.get(second).add(first);
    }
    

    然后通过深度优先遍历查找每一条边符合题目的个数.

    // 深度优先遍历
    // 当我们找到一个完整链路节点, 那么这些节点就不可能和剩下的节点有链接了
    // 假设找到某条无线边的所有节点为m个, 总结点数为n个. 那么相互不能到达的两两节点数为 m * (n - m)
    boolean[] visited = new boolean[n];
    long result  = 0;
    for(Integer key : cache.keySet()) {if(!visited[key]) {long count = dfs(key, cache, visited);result += (n - count) * count;}
    }
    

    对于深度优先遍历, 我们就没有啥好说的, 我们只需要按照常规方式进行递归即可.

    public int dfs(Integer key,  HashMap<Integer, ArrayList<Integer>> cache, boolean[] visited) {if(visited[key]) {return 0;}visited[key] = true;int count = 1;ArrayList<Integer> group = cache.get(key);for(Integer item : group) {if(visited[item] == false) {count += dfs(item, cache, visited);}}return count;
    }
    

    然后最后的计算结果因为所有的个数都计算了两遍, 我们需要除以2来求出最终的结果.

    return result/2;
    

    最后, 我们一起看一下整体的代码逻辑.

    class Solution {public long countPairs(int n, int[][] edges) {// 创建邻接表HashMap<Integer, ArrayList<Integer>> cache = new HashMap<>();for(int i = 0; i < n; i++) {cache.put(i, new ArrayList<>());}for(int[] item: edges) {Integer first = item[0];Integer second = item[1];cache.get(first).add(second);cache.get(second).add(first);}// 深度优先遍历// 当我们找到一个完整链路节点, 那么这些节点就不可能和剩下的节点有链接了// 假设找到某条无线边的所有节点为m个, 总结点数为n个. 那么相互不能到达的两两节点数为 m * (n - m)boolean[] visited = new boolean[n];long result  = 0;for(Integer key : cache.keySet()) {if(!visited[key]) {long count = dfs(key, cache, visited);result += (n - count) * count;}}return result/2;}public int dfs(Integer key,  HashMap<Integer, ArrayList<Integer>> cache, boolean[] visited) {if(visited[key]) {return 0;}visited[key] = true;int count = 1;ArrayList<Integer> group = cache.get(key);for(Integer item : group) {if(visited[item] == false) {count += dfs(item, cache, visited);}}return count;}
    }
    

    复杂度分析:

    • 时间复杂度: O(m + n), n 是总结点的个数, m是边数
    • 空间复杂度: O(m + n)

    结果如下所示.

http://www.yidumall.com/news/85653.html

相关文章:

  • 可以免费开发app的软件seo点击软件
  • 水利建设相关网站新媒体销售好做吗
  • 单位建设网站注意点广州今日头条新闻
  • 晋城网站建设科技有限公司百度快照是什么意思
  • 网站制作素材代码足球队世界排名榜
  • 网站建设方案的需求分析网站制作论文
  • 做网站用什么主机好郑州seo外包v1
  • 无人机东莞网站建设地推公司
  • 网站上的vR场景贴图怎么做的厦门seo总部电话
  • 龙华附近网站建设北京关键词优化服务
  • 网站做图标放在手机桌面东莞网站建设
  • 欧美男女直接做的视频网站企业推广策划方案
  • 创建全国文明城市时间广州seo招聘网
  • 建设网站 费用怎么在百度发帖
  • psd to wordpress网络搜索优化
  • 增城网站建设seo工具包括
  • 个人营业执照办理手续莆田百度seo公司
  • 百度网站优化软件百度搜索
  • 我自己做个网站怎么做厦门网站推广优化哪家好
  • 整站seoseo优化seo指的是搜索引擎
  • 注册公司流程和要求seocms
  • 网站系统目前运行稳定百度推广网站
  • 生成图片链接的网站某个网站seo分析实例
  • 怎么登录甘肃省建设厅网站离我最近的电脑培训中心
  • 网站的目录结构整站优化seo公司哪家好
  • 山东省建设管理中心网站首页北京网站优化经理
  • 西湖区外贸网站建设网络营销的核心是用户吗
  • 哈尔滨网站推广优化公司百度商务合作电话
  • 黑龙江省建设安全协会网站廊坊百度快照优化哪家服务好
  • 深圳龙岗招聘网seo关键词排名怎么提升