- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我听说大多数图形算法(但不是全部)都使用邻接表。我只是想知道哪些算法更喜欢邻接矩阵,为什么?
到目前为止,我发现 Floyd Warshall 使用邻接矩阵。
最佳答案
在算法中,邻接列表通常比邻接矩阵更快,在这些算法中,每个节点执行的关键操作是“遍历与该节点相邻的所有节点”。对于邻接列表,这可以在时间 O(deg(v)) 时间内完成,其中 deg(v) 是节点 v 的度数,而在邻接矩阵中需要时间 Θ(n)。类似地,邻接列表可以快速迭代图中的所有边 - 与邻接矩阵的时间 Θ(n2) 相比,这样做需要时间 O(m + n)。
一些最常用的图算法(BFS、DFS、Dijkstra 算法、A* 搜索、Kruskal 算法、Prim 算法、Bellman-Ford、Karger 算法等)需要对所有边或边进行快速迭代特定节点的事件,因此它们最适合邻接列表。
您提到 Floyd-Warshall 使用邻接矩阵。虽然 Floyd-Warshall 确实维护了一个内部矩阵来跟踪目前看到的最短路径,但它实际上并不要求原始图是邻接矩阵。动态规划工作的总成本为 Θ(n3),大于将邻接表转换为邻接矩阵的 O(n2) 成本或反之亦然。
只有少数地方邻接矩阵比邻接表快。邻接矩阵需要时间 O(1) 来测试图中是否存在特定边,这比邻接列表上相应操作的 O(deg(v)) 成本更快。由于将邻接列表转换为邻接矩阵的成本是 Θ(n2),因此邻接矩阵优于邻接列表的唯一情况是 (1) 边的随机访问是必需的,并且 (2) 算法的总运行时间为 o(n2)。我只知道执行此操作的一些算法。例如,有 celebrity-finding problem给你一张图,要求你找出是否有一个节点,每个节点都有入边,出边没有节点。这可以使用邻接矩阵在时间 O(n) 内完成,比使用邻接表更快。
(话虽这么说,您也可以使用用 cuckoo hash tables 表示的邻接列表而不是常规列表,并匹配与上面相同的运行时边界,尽管现在创建邻接列表的成本只是预期 要快而不是实际上最坏情况下的效率。)
我发现邻接矩阵有用的主要原因是从不同的角度考虑图。例如,将邻接矩阵提高到 k 次方会生成一个新矩阵,该矩阵计算从一个节点到另一个节点的路径数,恰好使用 k 跳。这可以用于 count and find triangles in graphs faster than the naive algorithm , 例如。同样,Four Russians algorithm用于计算图的传递闭包的方法是将图表示为矩阵,并使用一些巧妙的技术(将位 block 视为整数,然后在查找表中使用)以优于朴素搜索。
希望这对您有所帮助!
关于data-structures - 哪种图算法更喜欢邻接矩阵,为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62610614/
我收到一个错误: prefer_const_literals_to_create_immutables 在这个小部件上: child: Column( children: [
您发现自己最常使用这两种替代方案中的哪一个,哪一个更“惯用”? f arg (obj.DoStuff()) f 参数 <| obj.DoStuff() 最佳答案 总的来说,我不知道哪个更惯用。 就我个
经过一些搜索和测试,我了解了以下有关 lambda 表达式的事实。 1)当我们写一个lambda表达式时,编译器会为它创建一个匿名函数对象,并将其作为函数对象的一个实例; 2)lambda表达式的
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我更喜欢 dplyr 包中的函数 (select)。我加载了一个依赖于屏蔽选择功能的 MASS 包的包。除了约定 dplyr::select() 之外,是否有其他方法更喜欢从 dplyr 包中选择?
这个问题已经有答案了: Do rvalue references to const have any use? (8 个回答) 已关闭 9 年前。 在什么情况下您会更喜欢 void fun(const
我刚刚开始在 python 中使用 libsvm 并进行了一些简单的分类。 问题是我正在构建一个人脸检测系统,并且我想要一个非常低的错误拒绝率。另一方面,支持向量机似乎针对相同的错误拒绝和错误接受进行
我正在使用 GCC's atomic builtins增加一个共享的 volatile int。我只想增加值,我不关心返回值。为此,我应该选择 fetch_and_add 还是 add_and_fet
我在使用 Table View Controller 时遇到 iOS 11 的大标题问题。 我已经在 viewDidLoad 中将 prefersLargeTitles 设置为 true: overr
可以肯定地说,如果我不想在我的容器中重复,并且我不关心元素位置,因为我只想遍历容器,那么我应该使用 unordered_set 而不是 vector? 最佳答案 Is it safe to say t
我已经实现了 iOS 11 功能 prefersLargeTitles,它运行良好。纵向模式按预期工作: 我了解大标题在横向模式下始终保持折叠(小)状态,这对我来说很好。问题是当我尝试更改为横向然后再
这个问题在这里已经有了答案: MySQL vs PostgreSQL? Which should I choose for my Django project? (11 个答案) 关闭 7 年前。
我读过这个answer最后写了以下内容: Anything that you can with volatile can be done with synchronized, but not vice
我正在阅读 Jon Skeet 的书。 (#4) 但有一件事(除其他外)引起了我的注意: 主题: bool 值? 他在表格中写道:(X,Y 是 bool 值?) X | Y |
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: c difference between malloc and calloc 在任何情况下您更喜欢 mall
我使用包装在 UINavigationController 中的 UITableView 实现了一个基本的 UIViewController。我将 prefersLargeTitles 设置为 tru
我有很多 image/webp 图片,希望浏览器为 Safari 提供后备 image/jpg。 出于某种原因,Chrome(以及所有其他浏览器)仍在使用 jpg 图像而不是 webp。
我对 React 比较陌生;如果这是一个非常幼稚的问题,我深表歉意。 browserHistory有哪些技术优势?使其优于 hashHistory ?例如,使用 History API 是否有重大的性
如果我需要一个 Web 服务来回传递一个复杂的对象,我是否有理由更喜欢 SOAP 而不是 REST?以下是可能的 SOAP 消息示例: Joe abc123
我是一名优秀的程序员,十分优秀!