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

网站做优化有效吗软文有哪几种类型

网站做优化有效吗,软文有哪几种类型,平面设计作品欣赏,企业网站建设程序Hey我的编程小伙伴们👋,今天我要和大家分享一道我在LeetCode上遇到的超有趣的题目——编号3067的在带权树网络中统计可连接服务器对数目。这是一道非常适合练习DFS和图的题目哦!🤓💻 邻接图是什么? 在我们…

Hey我的编程小伙伴们👋,今天我要和大家分享一道我在LeetCode上遇到的超有趣的题目——编号3067的在带权树网络中统计可连接服务器对数目。这是一道非常适合练习DFS和图的题目哦!🤓💻

邻接图是什么?

在我们深入题目之前,先来聊聊邻接图。邻接图是一种表示图的数据结构,它将每个节点的邻居节点(即与该节点直接相连的节点)组织在一起。简单来说,邻接图就是一种方式,让我们快速知道任意一个节点都和哪些节点相连。🌍

为什么用邻接图?

  1. 直观表示:邻接图直观地表示了节点之间的关系,让我们一眼就能看出哪些节点是直接相连的。
  2. 高效查询:在邻接图中,查询任意两个节点之间是否存在边是非常快的。
  3. 适合树结构:对于树这样的无环图,邻接图可以很好地表示其结构,便于我们进行深度优先搜索(DFS)等操作。

题目解析

题目给出了一个无根带权树,树上有n个节点,每个节点都是一个服务器。还有一个edges数组,告诉我们哪些节点之间有连接以及连接的权重。🌐

关键的来了,我们需要找出所有可以通过某个中间节点c连接的服务器对ab。但不是随便哪个节点都能当中间人哦,要满足以下条件:

  1. a < b,且ab都不能是c
  2. ca和从cb的距离都能被signalSpeed整除。
  3. ca和从cb的路径不能有重叠的边。

暴力枚举的可能性

题目提示中n <= 1000,这意味着我们可以考虑使用暴力枚举的策略。因为节点的数量不是非常大,所以对每个节点进行遍历和计算是可行的。

算法思路

我们构建了一个邻接图来存储每个节点的连接信息。然后,通过深度优先搜索(DFS)遍历整棵树,计算每个节点作为中间节点时,能连接的服务器对的数目。🌳

代码实现

在Scala中,我们使用了ArrayBuffer来动态存储每个节点的邻居信息。DFS函数帮助我们递归地计算每个节点的贡献。最后,我们只需要遍历每个节点,累加它作为中间节点时能连接的服务器对数目。

import scala.collection.mutable.ArrayBufferobject Solution {def countPairsOfConnectableServers(edges: Array[Array[Int]], signalSpeed: Int): Array[Int] = {val n = edges.length + 1val graph = Array.fill(n)(ArrayBuffer[(Int, Int)]())for (e <- edges) {graph(e(0)) += ((e(1), e(2)))graph(e(1)) += ((e(0), e(2)))}def dfs(p: Int, root: Int, curr: Int): Int = {var res = 0if (curr == 0) {res += 1}for ((v, cost) <- graph(p)) {if (v != root) {res += dfs(v, p, (curr + cost) % signalSpeed)}}res}val res = new Array[Int](n)for (i <- 0 until n) {var pre = 0for ((v, cost) <- graph(i)) {val cnt = dfs(v, i, cost % signalSpeed)res(i) += pre * cntpre += cnt}}res}
}

时间和空间复杂度分析

  • 时间复杂度:由于我们对每个节点都执行了DFS,且每个节点的邻居都会被访问一次,时间复杂度为O(N + E),其中N是节点数,E是边数。在这个特定问题中,E接近N,所以时间复杂度接近O(N^2)。
  • 空间复杂度:我们使用了一个大小为N的数组来存储结果,以及一个邻接图,邻接图的空间复杂度取决于树的稠密程度。在最坏的情况下,如果树是完全二叉树,空间复杂度为O(N)。

结果

最终,我们得到了一个数组count,其中count[i]就是通过服务器i可连接的服务器对的数目。

#tag时间

  • #LeetCode挑战
  • #算法思维
  • #编程日常
  • #Scala编程
  • #树的深度优先搜索
  • #邻接图
  • #暴力枚举
  • #时间空间复杂度

希望我的分享对你有所帮助,如果你有更好的解法或者想法,欢迎在评论区留言讨论哦!我们一起进步,一起加油!🚀🌈

编程路上,我们一起成长,一起探索未知!👩‍💻🌟


以上就是今天的分享啦,如果你喜欢这样的内容,记得点赞和关注我哦!我们下次见!😘✨

http://www.mmbaike.com/news/76796.html

相关文章:

  • 贵阳哪家网站做优化排名最好网站引流推广
  • 把网站制作成app上海seo优化公司
  • 桂林手机网站建设网址链接生成器
  • 做网站送域名和邮箱网站推广方案策划
  • 专业地推团队seo优化外包
  • 网站设计师加油站seo研究中心南宁线下
  • 可以做哪些网站有哪些内容吗百度提交网址多久才会收录
  • 怎么建设营销型网站新乡seo网络推广费用
  • wordpress有自定义时间发布文章南京seo报价
  • 如何做网签合同 网站百度平台商家客服
  • 淘客做网站运营百度云资源
  • 做视频网站用什么服务器婚恋网站排名前三
  • 做网站要sql 数据库名字账号密码外链吧
  • 网页版wordpress教程视频周口seo公司
  • 电影网站做静态是不是好一些深圳全网推广平台
  • 网络工程实施方案保定seo外包服务商
  • 有口碑的南通网站建设小学四年级摘抄新闻
  • 使用 私有云 做视频网站网站推广优化c重庆
  • 可以做h5网站建站系统源码
  • 做lol数据的网站有哪些最新百度快速收录技术
  • 广州 Wix网站开发seo关键词排名优化哪好
  • 询价报价单模板seo职业培训学校
  • 广州网站建设智能 乐云践新百度搜图片功能
  • 企业网站产品分类多怎么做seo百度收录推广
  • wordpress前端注册插件aso优化师
  • 做网站教程下载搜索引擎优化需要多少钱
  • 视频网站直播怎么做百度seo运营工作内容
  • ecshop外贸网站流程优化四个方法
  • 网站建设公司的岗位职责360上网安全导航
  • 珠海网站惠州关键词排名提升