数据结构——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.mfbz.cn/a/558242.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

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

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

SD-WAN解决电商企业海外业务网络难题

全球化背景下,众多国内企业都涉及到海外贸易业务,尤其是出海电商得到蓬勃发展。企业做出海电商,需要访问国外网页、社交平台,如亚马逊、TikTok、Facebook、YouTube等与客户沟通互动,SD-WAN的发展正好为解决国际网络访问…

Vue2 移动端(H5)项目封装弹窗组件

前言 因vant-ui的dialog组件没有自定义footer插槽 效果 参数配置 1、代码示例&#xff1a; <t-dialog :visible.sync"show" :title"title" submit"submit"></t-dialog>2、配置参数&#xff08;t-dialog Attributes&#xff09; 参…

吹爆,一款实用的个人IT工具箱

作为一名开发人员&#xff0c;我们在日常工作和学习中常常需要使用一系列小工具&#xff0c;如JSON格式化、JSON转表格、当前时间戳、XML格式化、SQL格式化、密码生成以及UUID生成等。通常情况下&#xff0c;我们会在网上搜索各种在线工具来满足这些需求。 然而&#xff0c;这…

DePIN 赛道黑马,peaq network 如何打造全新 Web3 物联网?

当 Web2 公司仍对用户数据和资料进行“中心化”的收集与控制时&#xff0c;我们虽享受到了物联网技术的便利&#xff0c;却依旧没有逃脱个人数据和价值所有权的剥夺。由此&#xff0c;Web3 技术开始深入物联网世界&#xff0c;智能家居、智能汽车、智能手机都成为重要发力点&am…

冯喜运:4.19黄金,原油市场情绪分析:近期油价可能会回落?

【 黄金消息面解析】&#xff1a;周四(4月18日)&#xff0c;黄金上涨&#xff0c;现货金报每盎司2.384.83美元&#xff0c;上涨1%。中东地区持续的紧张局势未现缓和&#xff0c;继续扶持黄金逗留在历史高价位区域。周二美联储主席鲍威尔讲话&#xff0c;对何时可能降息三缄其口…

计算机比赛什么含金量高

acm含金量不如天梯&#xff0c;和蓝桥杯是同一层次 先说结论&#xff0c;根据专家讨论结果&#xff0c;蓝桥国一水平和icpc金牌含金量一样。&#xff08;doge 赢&#xff01;瑶瑶另先&#xff01; 会统计就多统计&#xff0c;我们acmer就是爱看这种数据 https://www.gxxsjs.co…

基于ssm高校宿舍管理系统论文

摘 要 当下&#xff0c;正处于信息化的时代&#xff0c;许多行业顺应时代的变化&#xff0c;结合使用计算机技术向数字化、信息化建设迈进。以前学校对于宿舍信息的管理和控制&#xff0c;采用人工登记的方式保存相关数据&#xff0c;这种以人力为主的管理模式已然落后。本人结…

探索 Nacos反序列化漏洞CNVD-2023-45001

在软件开发领域&#xff0c;安全漏洞是一项不容忽视的重要问题。最近&#xff0c;我们的安全团队发现了一个影响到我们的Nacos 2.1.0版本的反序列化漏洞&#xff0c;可能带来严重的安全威胁。我们已经立即采取了修复措施。本文将深入探讨这些漏洞的原理、可能造成的影响&#x…

拷贝构造函数与运算符重载

目录 一、拷贝构造函数 1.概念 2.特性 二、运算符重载 1.运算符重载 2.运算符重载实现的形式 3.赋值运算符重载 一、拷贝构造函数 1.概念 拷贝构造函数是一种特殊的构造函数&#xff0c;它在创建对象时&#xff0c;使用同一类中之前创建的对象来初始化新创建的对象…

C# 动态加载dll

方式1 using System; using System.Reflection;class Program {static void Main(){string dllPath "path/to/your/library.dll"; // 替换为你的DLL文件路径Assembly myAssembly Assembly.LoadFile(dllPath);Type myType myAssembly.GetType("YourNamespace…

力扣—2024/4/18—从双倍数组中还原原数组

代码实现&#xff1a; 快排 哈希表 ——超时 /*** Note: The returned array must be malloced, assume caller calls free().*/ void swap(int *m, int *n) {int temp *m;*m *n;*n temp; }// 快排 void sort(int *a, int l, int r) { // 左闭右开if (r - l < 2) {if (r…

MIMO(多天线)通信的四种译码算法

目录 一. 介绍 二. 极大似然译码 三. 破零译码算法 四. 最小均方误差算法 五. 球形译码 一. 介绍 发射天线数记为Mt&#xff0c;接收天线数记为Mr。由此发射信号x为向量&#xff1a; 接受信号y为向量&#xff1a; 信道H为矩阵&#xff1a; 利用n代表噪声向量&#xff0c;…

axios的封装理解和基本使用

axios的配置 ruoyi的前端对axios进行了封装&#xff0c;让我们发get请求或者是post请求更加方便了。 ruoyi对axios的封装在下面文件中&#xff1a;打开文件&#xff0c;可以看到它有三个显眼的方法&#xff0c;分别是request拦截器、response拦截器和通用下载方法。ruoYi接口地…

CommunityToolkit.Mvvm笔记---ObservableValidator

ObservableValidator 是实现 INotifyDataErrorInfo 接口的基类&#xff0c;它支持验证向其他应用程序模块公开的属性。 它也继承自 ObservableObject&#xff0c;因此它还可实现 INotifyPropertyChanged 和 INotifyPropertyChanging。 它可用作需要支持属性更改通知和属性验证的…

Redis中的Lua脚本(五)

Lua脚本 脚本复制 复制EVALSHA命令 EVALSHA命令式所有与Lua脚本有关的命令中&#xff0c;复制操作最复杂的一个&#xff0c;因为主服务器与从服务器载入Lua脚本的情况可能有所不同&#xff0c;所以主服务器不能像复制EVAL命令、SCRIPT LOAD命令或者SCRIPT FLUSH命令那样&…

2024 Polkadot Decoded 大会亮点前瞻,立即预定参会席位

原文&#xff1a;https://medium.com/polkadotnetwork/polkadot-decoded-2024-uniting-innovators-in-blockchain-technology-75fc3d8e93fe 作者&#xff1a;Polkadot 编译&#xff1a;OneBlock Polkadot 生态宣布他们的旗舰活动 —— Polkadot Decoded 将再次举行&#xff…

跟TED演讲学英文:How AI could empower any business by Andrew Ng

How AI could empower any business Link: https://www.ted.com/talks/andrew_ng_how_ai_could_empower_any_business Speaker: Andrew Ng Date: April 2022 文章目录 How AI could empower any businessIntroductionVocabularyTranscriptSummary后记 Introduction Expensiv…

von Mises-Fisher Distribution (Appendix 2)

5.3 Fast Python Sampler of the von Mises Fisher Distribution [3] 从论文中 p r o c e d u r e A n g l e G e n e r a t o r ( d , κ ) procedure~AngleGenerator(d, κ) procedure AngleGenerator(d,κ) 中的变换来看, 假设 y ∼ B e ( m − 1 2 , m − 1 2 ) y \sim …

Linux【实战】—— LAMP环境搭建 部署网站

目录 一、介绍 1.1什么是LAMP&#xff1f; 1.2LAMP的作用 二、部署静态网站 2.1 虚拟主机&#xff1a;一台服务器上部署多个网站 2.1.1 安装Apache服务 2.1.2 防火墙配置 2.1.3 准备网站目录 2.1.4 创建网站的配置文件 2.1.5 检查配置文件是否正确 2.1.6 Linux客户端…
最新文章