数据结构——6.4 图的应用

6.4 图的应用

  • 概念
  1. 最小生成树

    1. 对于一个带权连通无向图G =( E),生成树不同,每棵树的权(即树中所有边上的权值之和)也可能不同。设R为G的所有生成树的集合,若T为R中边的权值之和最小的生成树,则T称为G的最小生成树 (Minimum-Spannimg-Tree.MST)

      1. 最小生成树可能有多个,但边的权值之和总是唯一且最小的

      2. 最小生成树的边数 = 顶点数 - 1。砍掉一条则不连通,增加一条边则会出现回路

      3. 如果一个连通图本身就是一棵树,则其最小生成树就是它本身

      4. 只有连通图才有生成树,非连通图只有生成森林

    2. Prim 算法(普里姆):同一个图可能有多个最小生成树

      1. 从某一个顶点开始构建生成树;

      2. 每次将代价最小的新顶点纳入生成树,直到所有顶点都纳入为止。

      3. 总结:循环:点—该点最短边—点

    3. Kruskal 算法(克鲁斯卡尔)

      1. 每次选择一条权值最小的边,使这条边的两头连通(原本已经连通的就不选)

      2. 直到所有结点都连通

      3. 总结:循环:全局最短边构成一片片岛屿—最后岛屿相连成大陆

    4. 两个算法的比较

克鲁斯卡尔算法和普林姆算法都是用于求解加权连通图的最小生成树的经典算法,但它们在实现方式和特点上有所不同。

克鲁斯卡尔算法的基本思想是按照权值从小到大的顺序选择n-1条边,并保证这些边不构成回路。它首先构造一个只含n个顶点的森林,然后根据权值从小到大从连通网中选择边加入到森林中,并使森林中不产生回路,直至森林变成一棵树为止。克鲁斯卡尔算法的时间复杂度为O(eloge),其中e为网中的边数,因此它适合于求边稀疏的网的最小生成树。

普林姆算法则是从一个起始节点开始,不断选择与当前集合相连且权值最小的边,并将其加入到集合中。在这个过程中,不断扩大当前集合的规模,直到所有的节点都被加入到集合中为止。普林姆算法的时间复杂度与图中顶点的数量有关,因此它在某些情况下可能比克鲁斯卡尔算法更高效。

总的来说,克鲁斯卡尔算法和普林姆算法都是有效的求解最小生成树的算法,它们各有特点,可以根据具体问题的特点选择适合的算法。对于边数较少的稀疏图,克鲁斯卡尔算法可能更为合适;而对于顶点数较少的图,普林姆算法可能更具优势。在实际应用中,可以根据具体情况选择适合的算法进行求解。

  1. 最短路径问题

    1. BFS求无权图的单源最短路径(无权图)

      1. 即构建以出发顶点为根的广度优先生成树

      2. 结点的高度即为最短路径长度

      3. 原理:广度优先生成树的高度是最低的

      4. 缺点:只适用于各边权值相等的图或无权图,即求的是最短的边数

    2. Dijkstra算法:求带权图的单源最短路径(带权图、无权图)

      1. 标记起点为完成路径寻找,起点到起点的距离为0

      2. 列出其他所有点到当前标记点的距离,不直接相连的顶点距离设置为∞

      3. 将距离加在目标点到起点的距离上,若小于原来的路径数据,则更新成最小值

      4. 移到未被标记且距离值最小的点上,重复②③,直到完成。

      5. 与Prim算法的对比

        1. Prim算法每次寻找最短边,不做加法

        2. Dijkstra算法寻找短边要更新最短路径

        3. 二者执行过程相似,复杂度都是O(n²),即O(v²)

      6. 带负权值边的图中Dijkstra算法没有用

    3. Floyd算法求各顶点间最短路径(带权图、无权图)

      1. 列出图的临界矩阵

      2. 考虑一个顶点作为中转点的情况,将邻接矩阵的边更新为最小边,更新边在path矩阵的相应位置填入中转点

      3. 更新后的矩阵继续进行②,直到所有顶点都考虑过,算法完成

  2. 有向无环图(DAG图):若一个有向图中不存在环,则称为有向无环图,简称DAG图 (Directed Acyclic Graph)

    1. 有向无环图简化描述算式

    2. (https://img-home.csdnimg.cn/images/20230724024159.png?origin_url=media%2Fimage49.png&pos_id=img-TCL4uiTJ-1707574201371)

  3. AOV网

    1. AOV网中不允许存在环路(本质是DAG图)

    2. 拓扑排序

      1. 实现

        1. 从AOV网中选择一个没有前驱 (入度为0) 的顶点并输出

        2. 从网中删除该顶点和所有以它为起点的有向边。

        3. 重复1) 和2) 直到当前的AOV网为空或当前网中不存在无前驱的顶点为止(说明有回路)。

      2. 定义

        1. 拓扑排序:在图论中,由一个有向无环图的顶点组成的序列,当且仅当满足下列条件时,称为该图的一个拓扑排序:

          1. 每个顶点出现且只出现一次。

          2. 若顶点A在序列中排在顶点B的前面,则在图中不存在从顶点B到顶点A的路径。

        2. 或定义为:拓扑排序是对有向无环图的顶点的一种排序,它使得若存在一条从顶点A到顶点B的路径,则在排序中顶点B出现在顶点A的后面。

        3. 每个AOV网都有一个或多个拓扑排序序列

      3. 时间复杂度

        1. 时间复杂度:O(V+E)

        2. 若采用邻接矩阵,则需O(V²)

      4. 逆拓扑排序

        1. 从AOV网中选择一个没有后继 (出度为0) 的顶点并输出

        2. 从网中删除该顶点和所有以它为终点的有向边。

        3. 重复1) 和2) 直到当前的AOV网为空

      5. 逆邻接表:

        1. 正常的邻接表,边表是顶点指向的点,

        2. 逆邻接表,边表是指向顶点的点

      6. DFS算法实现逆拓扑排序

  4. 关键路径

    1. AOE网的概念与性质

      1. 概念:在带权有向图中,以顶点表示事件,以有向边表示活动,以边上的权值表示完成该活动的开销(如完成活动所需的时间)称之为用边表示活动的网络,简称AOE网(Activity On Edge NetWork)

      2. AOE网具有以下两个性质

        1. 只有在某顶点所代表的事件发生后,从该顶点出发的各有向边所代表的活动才能开始;

        2. 只有在进入某顶点的各有向边所代表的活动都已结束时,该顶点所代表的事件才能发生。

        3. 另外,有些活动是可以并行进行的

    2. AOE网的关键路径

      1. 在AOE网中

        1. 仅有一个入度为0的顶点,称为开始顶点 (源点),它表示整个工程的开始;

        2. 也仅有一个出度为0的顶点,称为结束顶点 (汇点),它表示整个工程的结束

      2. 从源点到汇点的有向路径可能有多条,所有路径中,具有最大路径长度的路径称为关键路径,而把关键路径上的活动称为关键活动

      3. 完成整个工程的最短时间就是关键路径的长度,若关键活动不能按时完成,则整个工程的完成时间就会延长

    3. 求AOE网关键路径(事件:顶点,活动:边)

      1. 两个最早:(从前往后推)

        1. 事件v_(k)的最早发生时间ve(k)——决定了所有从v_(k)开始的活动能够开工的最早时间

        2. 活动a_(i)的最早开始时间e(i)——指该活动弧的起点所表示的事件的最早发生时间

      2. 两个最迟:(从后往前推)

        1. 事件v_(k)的最迟发生时间vl(k)——它是指在不推迟整个工程完成的前提下,该事件最迟必须发生的时间

        2. 活动a_(i)的最迟开始时间1(i)——它是指该活动弧的终点所表示事件的最迟发生时间与该活动所需时间之差

      3. 活动a_(i)的时间余量:d(i)=1(i)-e(i)——表示在不增加完成整个工程所需总时间的情况下,活动a_(i)可以拖延的时间

      4. 若一个活动的时间余量为零,则说明该活动必须要如期完成,d(i)=0即1(i)=e(i)的活动a_(i)是关键活动

      5. 由关键活动组成的路径就是关键路径

      6. 求关键路径的方法

      7. 关键活动、关键路径的特性

        1. 若关键活动耗时增加,则整个工程的工期将增长

        2. 缩短关键活动的时间,可以缩短整个工程的工期

        3. 当缩短到一定程度时,关键活动可能会变成非关键活动

        4. 可能有多条关键路径,只提高一条关键路径上的关键活动速度并不能缩短整个工程的工期,只有加快那些包括在所有关键路径上的关键活动才能达到缩短工期的目的。

  • 理解
  1. 最短路径一定是简单路径

  2. 最小生成树的算法基于贪心策略,每次都选取权值最小且满足条件的边,如果各边权值不同,则每次选择的新顶点也是唯一的,因此最小生成树也唯一

  3. 求关键路径过程的描述

    1. 事件最早发生时间Ve:起点为0,其他点取各入度路径长度中最大的(上一个指向该点的点的最早时间加上边的长度的最大值)

    2. 事件最晚发生时间Vl:终点为其最早发生时间,其他为各出度路径长度中最小的(上一个由该点指向点的最晚时间减去边长度的最小值)

    3. 活动最早发生时间e:边的最早发生时间,即为该有向边起点(无箭头一端)的最早发生时间

    4. 活动最晚发生时间l:边的最晚发生时间,即为该有向边终点(有箭头一端)的最晚发生时间减去该边的权值

  • 技巧
  1. 无向连通图存在权值相同的多条边时,最小生成树可能不是唯一的

  2. 无向连通图的最小生成树一定存在

  3. Dijkstra算法适合求解有回路的带权图的最短路径,也可以求两个顶点的最短路径

  4. Floyd算法求两个顶点的最短路径时,当最短路径发生改变,path_(k)会在path_(k-1)的基础上更新,因此二者会失去子集关系

  5. 能判断有向图是否有环的方法

    1. 深度优先遍历:生成树上:下一个结点是当前结点的父节点

    2. 拓扑排序:存在入度消不掉的点

  6. 若有向图的拓扑有序序列唯一,每个顶点的入度和出度不一定为1,例如下图:

  7. 拓扑排序中每一次操作都溢出当前入度为0的结点,如果一次移除若干个结点,这些结点的先后顺序不影响正确性,因此如果需要暂存,使用栈或队列都可以

  8. 顶点数大于1的强连通分量=环

  9. 若一个有向图具有有序的拓扑排序序列(0,1,2,3,…)则邻接矩阵一定上三角

  10. 有向图的邻接矩阵中,主对角线以下元素均为0,则该图的拓扑序列,存在且不唯一,例如:三点两边有向图:①→②,①→③,有两个拓扑序列

  11. 强连通分量数目的计算:

    1. 当一个顶点没有入度时表明没有别的点能够到达它,因此该点组成一个强连通分量

    2. 环构成一个强连通分量

  12. Dijkstra算法高度相似Prim算法,但是Dijkstra算法在求生成树时,未必能求到最小生成树

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/598.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【华为OD机试】跳马【C卷|200分】

【华为OD机试】-真题 !!点这里!! 【华为OD机试】真题考点分类 !!点这里 !! 题目描述 马是象棋(包括中国象棋和国际象棋)中的棋子,走法是每步直一格再斜一格, 即先横着或者直者走一格,然后再斜着走一个对角线,可进可退,可越过河界,俗称"马走日"字。 给定 m…

如何在 Ubuntu 14.04 上更改 PHP 设置

简介 PHP 是一种服务器端脚本语言,被许多流行的 CMS 和博客平台如 WordPress 和 Drupal 所使用。它也是流行的 LAMP 和 LEMP 堆栈的一部分。更新 PHP 配置设置是设置基于 PHP 的网站时的常见任务。定位确切的 PHP 配置文件可能并不容易。通常在服务器上会有多个 PH…

弹性盒子(display: flex)布局

以下文章都可以参考 CSS - 完美解决 flex 布局下,一行显示固定个数(平均分布)并且强制换行,超出后 “靠左“ 对其(详细解决方案,适用于 Web、Vue、React 等任何前端项目)_flex设置一行几个-CSD…

linux下使用qt+mpv调用GPU硬件解码

linux下GPU硬件解码接口,常用的有vdpau和vaapi。 mpv是基于mplayer开发的一个播放器。此外,mpv还提供了函数库libmpv,通过使用libmpv可以编写一个简单的播放器。 基于qtlibmpv的demo,官方例子代码如下:https://github.…

Quick Service Setup(快速服务设置)

Quick Service Setup界面使用户能够使用最少的参数快速配置和编辑简单的应用程序服务。Alteon自动为虚拟服务创建所需的对象(虚拟服务器、服务器组、真实服务器、SSL策略、FastView策略等)。通过快速服务设置,您可以配置HTTP, HTTPS,基本slb(第4层TCP或U…

Python-VBA函数之旅-classmethod函数

目录 一、装饰器的定义: 二、装饰器类型: 三、装饰器的主要用途: 四、classmethod常用场景: 1、classmethod函数: 1-1、Python: 1-2、VBA: 2、相关文章: classmethod是 Pyth…

【运维篇#2】查看每个docker的日志量并且清除多余日志

文章目录 清除日志查看现在每个docker容器中的日志量 清除日志 #!/bin/bash echo " start clean docker containers logs " logs$(find /var/lib/docker/containers/ -name *-json.log) for log in $logsdoecho "clean logs : $log"cat /dev/null > $l…

【LeetCode热题100】【矩阵】旋转图像

题目链接:48. 旋转图像 - 力扣(LeetCode) 要将一个矩阵顺时针旋转90,数学公式是new[j][n-i-1]old[i][j],要原地翻转的话,可以先水平翻转,即变成m[n-i-1][j],再主对角线翻转&#xf…

定时器详解

定时器:Timer类 常用方法方法: 1.schedule(TimeTask timetask,long delay,(long period)): TimeTask:实现了Runnable类,实现时需要重写run方法 delay:表示延迟多少(decay)后开始执行任务,单位是毫秒&#x…

java算法day2

螺旋矩阵搜索插入位置查找元素第一个位置和最后一个位置 螺旋矩阵 解法:模拟,核心在于你怎么转,还有就是处理边界,边界如何收缩,什么时候停止旋转。最内圈的时候怎么处理。 通过上图的模拟来解决这个问题:…

SpringBoot-自定义注解AOP实现及拦截器示例

SpringBoot-自定义注解AOP实现及拦截器示例 一、四大元注解 当你在编写自定义注解时,Target、Retention、Documented 和 Inherited 是四个你可能会用到的元注解,它们可以帮助你更好地定义和使用注解。 1、Target Target 注解用于指定注解可以应用的程…

【科研入门】评价指标AUC原理及实践

评价指标AUC原理及实践 目录 评价指标AUC原理及实践一、二分类评估指标1.1 混淆矩阵1.2 准确率 Accuracy定义公式局限性 1.3 精确率 Precision 和 召回率 Recall定义公式 1.4 阈值定义阈值的调整 1.5 ROC与AUC引入定义公式理解AUC算法 一、二分类评估指标 1.1 混淆矩阵 对于二…

【muzzik 分享】关于 MKFramework 的设计想法

MKFramework是我个人维护持续了几年的项目(虽然公开只有一年左右),最开始由于自己从事QP类游戏开发,我很喜欢MVVM,于是想把他做成 MVVM 框架,在论坛第一个 MVVM 框架出来的时候,我的框架已经快完…

函数调用栈中的栈帧形成了一个链式结构

下面是一个简单的 C 示例&#xff0c;演示了函数调用栈的概念&#xff1a; #include <iostream>// 递归函数&#xff0c;计算阶乘 int factorial(int n) {if (n 0 || n 1) {return 1;} else {return n * factorial(n - 1); // 递归调用} }int main() {int result fac…

电机控制专题(二)——Sensorless之扩展反电动势EEMF

文章目录 电机控制专题(二)——Sensorless之扩展反电动势EEMF前言理论推导仿真验证总结参考文献 电机控制专题(二)——Sensorless之扩展反电动势EEMF 前言 总结下电机控制中的扩展反电动势模型。 纯小白&#xff0c;如有不当&#xff0c;轻喷&#xff0c;还请指出。 在得出E…

代码随想录算法训练营Day17 | 110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和 | Python | 个人记录向

本文目录 110.平衡二叉树做题看文章 257. 二叉树的所有路径做题看文章 404.左叶子之和做题看文章 以往忽略的知识点小结个人体会 110.平衡二叉树 代码随想录&#xff1a;110.平衡二叉树 Leetcode&#xff1a;110.平衡二叉树 做题 今天算是第一次用递归做出来了&#xff0c;之…

《神经网络与深度学习:案例与实践》动手练习1.3

飞桨AI Studio星河社区-人工智能学习与实训社区 动手练习1.3 执行上述算子的反向过程&#xff0c;并验证梯度是否正确。 import mathclass Op(object):def __init__(self):passdef __call__(self, inputs):return self.forward(inputs)# 前向函数# 输入&#xff1a;张量inpu…

synchronized锁升级原理

锁升级过程 jdk1.6之后的优化 synchronized锁有四种状态&#xff0c;无锁&#xff0c;偏向锁&#xff0c;轻量级锁&#xff0c;重量级锁&#xff0c;这几个状态会随着竞争状态逐渐升级&#xff0c;锁可以升级但不能降级&#xff0c;但是偏向锁状态可以被重置为无锁状态。 1、偏…

深入挖掘C语言 ---- 文件操作

目录 1. 文件的打开和关闭1.1 流和标准流1.1.1流1.1.2标准流 1.2 文件指针1.3 文件的打开和关闭 2. 顺序读写3. 随机读写3.1 fseek3.2 ftell3.3 rewind 4. 读取结束判定 正文开始 1. 文件的打开和关闭 1.1 流和标准流 1.1.1流 我们程序的数据需要输出到各种外部设备, 也需要…

CentOS7升级openssl

文章目录 一 系统环境二 操作步骤三 版本检查 一 系统环境 公司服务器等保要求&#xff0c;修复openssl的高危漏洞。 本机使用centos7.9系统&#xff0c;openssl版本是1.0.2k&#xff0c;计划升级到1.1.1q 在执行下列操作前&#xff0c;务必要打快照做好备份&#xff0c;以防升…