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

第五章 图

第五章 图

  • 图的基本概念
    • 图的应用背景
    • 图的定义和术语
  • 图的存储结构
    • 邻接矩阵
    • 邻接表
  • 图的遍历
    • 连通图的深度优先搜索
    • 连通图的广度优先搜索
  • 图的应用
    • 最小生成树
    • 拓扑排序
  • 小试牛刀

图的基本概念

图结构中,任意两个结点之间都可能相关;而在树中,结点具有层次关系,每一层结点只能和上一层至多一个结点相关,但可能和下一层多个结点相关

图的应用背景

在这里插入图片描述

  • 上图中圆圈称为顶点;连线称为边,连线附带的数值称为边的权
  • 图结构可以用来描述通信网络

图的定义和术语

在这里插入图片描述

图G由两个集合V和E组成,记作G=(V,E);V是顶点的集合(有穷非空),E是边的集合

  • 有向图:边是有序的(边带箭头“单行道”、用<顶点1,顶点2>表示从顶点1到顶点2的边);无向图:边是无序的(边不带箭头、用(顶点1,顶点2)表示顶点1和2之间的边)
  • 弧,弧头,弧尾;弧:有向图的边称为弧;<v,w>表示从v到w的一条弧,其中v称为弧尾(或始点),w称为弧头(或终点)

任何两点之间都有边的无向图称为无向完全图;任何两点之间都有弧的有向图称为有向完全图

  • 权:图的边的附带数值,实际应用中可以表示从一个顶点到另一个顶点的距离、代价或耗费等
  • 带权图:每条边都带权的图称为带权图
  • 顶点的度D、入度ID、出度OD:无向图中顶点的度是与该顶点相关联的边的数目,有向图中则把以顶点为终点的弧的数目称为该顶点的入度,以该顶点为始点的弧的数目称为该顶点的初读,有向图中的度为入度和出度的和
  • 子图:设G=(V,E)是一个图,若E是E的子集,V是V的子集,并且E中的边仅有与V中的顶点相关联。则G称为G的子图
  • 路径、路径长度:从一个顶点到另一个顶点称为路径;路径长度就是路径(或弧)上边的数之和
  • 简单路径、回路、简单回路;简单路径:序列中顶点不重复出现;第一个顶点和最后一个顶点相同的路径称为回路或环;除了第一个顶点和最后一个顶点外,其余顶点不重复的回路称为简单回路或简单环
  • 连通、连通图、联通分量;连通图:在无向图中,如果从顶点v到顶点v有路径,则称其为连通;连通图:图中任意两个顶点都是连通的;连通分量:无向图中的极大连通子图
  • 强连通、强连通图、强连通分量;强连通图:有向图任意一对顶点双向连通;强连通分量:有向图的极大连通子图
  • 生成树、生成森林;生成树:包含所有顶点的一个极小连通子图;生成森林:在非连通图中,每个连通分量都可得到一个极小的连通子图,即一棵生成树,这些连通分量的生成树就组成了一个非连通图的生成森林

图的存储结构

邻接矩阵

  • 二维矩阵来实现,两顶点连通为1,不连通为0,行,列分别表示全部顶点,如下图所示:

在这里插入图片描述
注:也可用邻接矩阵表示带权图,没有边的用无穷表示,有的则用权,其余正常

邻接表

邻接表是顺序存储与链式存储相结合的存储方式

在这里插入图片描述

  • 有向图的邻接表;以顶点Vi为尾的弧

  • 无向图的邻接表;第i个单链表中的结点表示依赖于Vi的边

在这里插入图片描述

  • 逆邻接表:逆邻接表是指以每个顶点作为索引,记录各个顶点的入边(即指向该顶点的边)的数据结构。(有向图的邻接表记录的是出边)

在这里插入图片描述

图的遍历

图的遍历是指从图的某个顶点出发,系统的访问图的每个顶点,并且每个顶点只能被访问一次

连通图的深度优先搜索

以图中某个顶点出发,首先访问出发点,然后任选一个未访问过的邻接点,以邻接点为新出发点继续,依此类推,直到所有顶点都被访问

在这里插入图片描述

连通图的广度优先搜索

从图中某个顶点出发,访问了该顶点后依次访问该顶点的邻接点,然后从邻接点出发继续访问直到结束

在这里插入图片描述

图的应用

最小生成树

对于有n个顶点的无向图,所有生成树都有且仅有n-1条边

  • Prim算法(假设G=(V,E)是一个带权图,生成的最小生成树为MinT=(V,T),其中V为顶点的集合,T为边的集合)
    • 初始化:U={u0},T={}。其中U为一个新设置的顶点的集合,初始U中只含有顶点u0,这里假设从顶点u0出发
    • 对所有u∈U,v∈V-U中,找一条权最小的边(u,v),将这条边加入集合T中,将顶点v加入集合U中
    • 如果U=V,则算法结束,否则重复

在这里插入图片描述

  • 克鲁斯卡尔算法
    • 设G=(V,E),令最小生成树初始状态为只有n个顶点而无边的非连通图T=(V,{}),每个顶点自成一个连通分量
    • 在E中选取代价最小的边,若该边依附的顶点落在T中不同的连通分量上,则将此边加入到T中,否则舍去此边,选取下一条代价最小的边
    • 依此类推,直到T中所有顶点都在同一连通分量上为止
  • Dijkstra求单源最短路径(设置顶点集合S,开始时S中只含有源点v)
    在这里插入图片描述
    • 创建一个节点集合,初始时只包含起点节点,以及一个距离表记录起点到各个节点的当前最短距离和路径。
    • 从起点开始,遍历与起点相邻的节点,并更新距离表中的距离和路径。
    • 选择一个距离表中未访问过的节点中距离最短的节点,将其加入节点集合中,并继续遍历与该节点相邻的节点。若找到更短的路径,更新距离表中的距离和路径。
    • 重复步骤3,直到所有节点都被加入节点集合,或者目标节点被加入节点集合。最终,距离表中记录的就是起点到各个节点的最短距离和路径。

拓扑排序

  • AOV网:工程或者某种流程可分为若干个小的工程或阶段,这些小的工程或阶段就称为活动;若以图中顶点表示活动,有向边表示活动之间的优先关系,这种有向图称为AOV网

在这里插入图片描述

  • 拓扑排序

完成拓扑排序的前提条件是AOV网中不能出现回路

有向图拓扑排序算法的基本步骤如下:

- 图中选择一个入度为0的顶点,输出该顶点
- 从图中删除该顶点及其相关联的弧,调整被删弧的弧头结点的入度(入度减1)
- 重复执行上述步骤直到所有入度为0的顶点均被输出

在这里插入图片描述

小试牛刀

  • 一个有n个顶点的无向连通图,最少有______条边
  • 无向图的邻接矩阵是_______矩阵
  • 给出下图的邻接矩阵和邻接表
    在这里插入图片描述
  • 分别给出下图的邻接矩阵、邻接表和逆邻接表

在这里插入图片描述

  • 分别给出下图从v5出发按深度优先搜索和广度优先搜索算法遍历得到的顶点序列

在这里插入图片描述

相关文章:

第五章 图

第五章 图 图的基本概念图的应用背景图的定义和术语 图的存储结构邻接矩阵邻接表 图的遍历连通图的深度优先搜索连通图的广度优先搜索 图的应用最小生成树拓扑排序 小试牛刀 图的基本概念 图结构中&#xff0c;任意两个结点之间都可能相关&#xff1b;而在树中&#xff0c;结点…...

深度学习实战:用Keras搭建深度学习网络做手写数字识别

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ 🐴作者:秋无之地 🐴简介:CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作,主要擅长领域有:爬虫、后端、大数据开发、数据分析等。 🐴欢迎小伙伴们点赞👍🏻、收藏⭐️、…...

算法解析:LeetCode——机器人碰撞和最低票价

摘要&#xff1a;本文由葡萄城技术团队原创并首发。转载请注明出处&#xff1a;葡萄城官网&#xff0c;葡萄城为开发者提供专业的开发工具、解决方案和服务&#xff0c;赋能开发者。 机器人碰撞 问题&#xff1a; 现有 n 个机器人&#xff0c;编号从 1 开始&#xff0c;每个…...

LeetCode刷题总结 - LeetCode 热题 100 - 持续更新

LeetCode 热题 100 其他系列哈希1. 两数之和49. 字母异位词分组128. 最长连续序列 双指针27. 移除元素283. 移动零11. 盛最多水的容器剑指 Offer II 007. 数组中和为 0 的三个数42. 接雨水 滑动窗口438. 找到字符串中所有字母异位词3. 无重复字符的最长子串 字串560. 和为 K 的…...

Spring是什么?为什么要使用Spring?

目录 前言 一、Spring是什么&#xff1f; 1.1 轻量级 1.2 JavaEE的解决方案 二、为什么要使用Spring 2.1 传统方式完成业务逻辑 2.2 使用Spring模式完成业务逻辑 三、为什么使用Spring&#xff1f; 前言 本文主要介绍Spring是什么&#xff0c;并且解释为何要去使用Spring&…...

自我监督学习日志

学习日志 10.12 一天学不了一分钟&#xff0c;不知道为什么也就是了 今天一定要学一个小时&#xff01; 机器学习就是机器帮我们找一个函数 语音辨识&#xff0c;语音&#xff0c;声音讯号 转化为文字 帮我们找一个人类写不出来的复杂函数 类神经网络 输入 一张图片用一个矩…...

配置CA证书

前置条件 配置Java环境变量。 具体操作 windows环境 以管理员方式执行CMD窗口&#xff0c;输入命令&#xff1b; cd /d %JAVA_HOME%\jre\lib\securitycurl -kv https://xxx/artifactory/CMC-Release/certificates/xxxRootCA.cer -o xxxRootCA.cercurl -kv https://xxx/art…...

计算机毕业设计选什么题目好?springboot 高校就业管理系统

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…...

上海-华为全联接大会|竹云受邀参加华为云ROMAConnect行业生态联盟成立联合发布会

2023年9月22日&#xff0c;在上海举办的华为全联接大会上&#xff0c;竹云作为华为云全方位合作伙伴代表&#xff0c;受邀参加华为云ROMAConnect行业生态联盟成立联合发布会。华为云PaaS服务产品部副部长张甲磊以及联盟主要成员企业出席发布仪式&#xff0c;共同见证华为云ROMA…...

走进GraalVM

是什么 GraalVM是一个高性能的JDK&#xff0c;旨在加速用Java和其他JVM语言编写的应用程序的执行&#xff0c;同时还为JavaScript&#xff0c;Python&#xff0c;Ruby和许多其他流行语言提供运行特点 GraalVM可以代替JDK、JVM之前的工作。 GraalVM除了支持Java&#xff0c;也支…...

spark读取hive表字段,区分大小写问题

背景 spark任务读取hive表&#xff0c;查询字段为小写&#xff0c;但Hive表字段为大写&#xff0c;无法读取数据 问题错误: 如何解决呢&#xff1f; In version 2.3 and earlier, when reading from a Parquet data source table, Spark always returns null for any column …...

UE4和C++ 开发-头文件(.h) 和实现文件(.cpp)区别

.h文件和.cpp文件是C程序中的两种不同类型的文件。 .h文件通常包含类、函数和变量的声明&#xff0c; 而.cpp文件包含这些声明的实现。 .h文件中的声明通常是公共的&#xff0c;可以被其他文件包含和使用。.cpp文件中的实现通常是私有的&#xff0c;只能在该文件中使用。 在…...

git介绍和安装、(git,github,gitlab,gitee介绍)、git工作流程、git常用命令、git忽略文件

1 git介绍和安装 2 git&#xff0c;github&#xff0c;gitlab&#xff0c;gitee介绍 3 git工作流程 4 git常用命令 5 git忽略文件 1 git介绍和安装 首页功能写完了---》正常应该提交到版本仓库---》大家都能看到这个---》 运维应该把现在这个项目部署到测试环境中---》测试…...

go cpu、内存监控、性能分析:PProf

PProf PProf 是什么 PProf是 golang 官方提供的性能调优分析工具&#xff0c;用于分析和优化Go程序的性能。 PProf通过收集和分析程序的运行时数据来生成性能分析报告。它使用Go语言的运行时特性&#xff0c;如代码注释和特殊的程序运行标记&#xff0c;来收集性能数据。PPr…...

计算机网络传输层知识总结·

传输层提供的服务 传输层的功能 ●传输层提供进程之间的逻辑通信&#xff0c;即端到端的通信 ●复用和分用 ●差错检测&#xff08;首部和数据部分&#xff09; ●面向连接的TCP和无连接的UDP 端口的作用 ●端口标识的是主机中的进程 ●硬件端口是不同…...

vue使用ant design Vue中的a-select组件实现下拉分页加载数据

<a-form-model-item :labelCol"labelCol" :wrapperCol"wrapperCol" prop"equipmentTypeId" label"所属设备种类"> <a-select v-model"model.equipmentTypeId" popupScroll"handlePopupScroll" placehold…...

精准突击!GitHub星标103k,2023年整理1658页JAVA秋招面试题

前言&#xff1a; 现在的互联网开发岗招聘&#xff0c;程序员面试背八股文已经成为了不可逆转的形式&#xff0c;其中一个Java岗几百人在投简历也已经成为了常态&#xff01;更何况一份面试题动辄七八百道&#xff0c;你吃透了&#xff0c;技术只要不是很差&#xff0c;面试怎…...

GEE:基于GLDAS数据集分析土壤湿度的时间序列变化

作者:CSDN @ _养乐多_ 本篇博客将介绍如何使用Google Earth Engine(GEE)进行土壤湿度数据的分析。我们将使用NASA GLDAS(Global Land Data Assimilation System)数据集,其中包括了关于土壤湿度的信息。通过该数据集,我们将了解土壤湿度在特定区域和时间段内的变化,并生…...

Nacos安装

Nacos安装 1.Windows安装 1.1.下载安装包 在Nacos的GitHub页面&#xff0c;提供有下载链接&#xff0c;可以下载编译好的Nacos服务端或者源代码&#xff1a; GitHub主页&#xff1a;https://github.com/alibaba/nacos GitHub的Release下载页&#xff1a;https://github.co…...

UE4和C++ 开发-C++与UMG的交互2(C++获取UMG的属性)

1、...C获取UMG的属性 1.1、第一种方法&#xff1a;通过名称获取控件。 void UMyUserWidget::NativeConstruct() {Super::NativeConstruct();//通过名字&#xff0c;获取蓝图控件中的按钮引用。CtnClic Cast<UButton>(GetWidgetFromName(TEXT("Button_44"))…...

手把手教你用TMS320F2803x DSP实现PMBus通信(附代码下载与避坑指南)

TMS320F2803x DSP实战&#xff1a;PMBus通信从零搭建到波形调试全攻略 1. 工程搭建与开发环境配置 在开始PMBus通信开发前&#xff0c;需要准备完整的软硬件环境。以下是基于TI C2000系列DSP的典型配置流程&#xff1a; 硬件准备清单&#xff1a; TMS320F2803x开发板&#xff0…...

CircuitPython库管理实战:从安装优化到API深度应用

1. 项目概述与核心价值在嵌入式硬件开发的世界里&#xff0c;CircuitPython以其极低的入门门槛和“即写即得”的交互体验&#xff0c;成为了连接创意与现实的绝佳桥梁。无论是点亮第一颗LED&#xff0c;还是驱动复杂的传感器网络&#xff0c;其丰富的库生态系统都是项目成功的基…...

LabVIEW新手必看:5分钟搞定TCP连接TLINK物联网平台(附完整VI程序)

LabVIEW物联网开发实战&#xff1a;从零构建TCP通信系统 引言 在工业自动化和物联网应用开发领域&#xff0c;LabVIEW因其图形化编程特性成为工程师快速搭建原型系统的利器。TCP协议作为最可靠的网络传输方式之一&#xff0c;与LabVIEW结合能够为设备联网提供稳定通道。不同于传…...

Linux编译OpenSSL 3.0.1时,那个烦人的‘Can‘t locate IPC/Cmd.pm’错误,我是这样解决的

解决Linux编译OpenSSL 3.0.1时的Perl模块依赖问题 在Linux环境下从源码编译安装OpenSSL时&#xff0c;开发者常会遇到各种依赖问题&#xff0c;其中Cant locate IPC/Cmd.pm错误尤为常见。这个错误看似简单&#xff0c;却可能让不熟悉Perl模块管理机制的用户陷入困境。本文将深入…...

Redis Sentinel:主从架构的自动保镖详解

Redis 哨兵&#xff08;Sentinel&#xff09;&#xff1a;主从架构的「自动保镖」 在 Redis 主从复制经典架构当中&#xff0c;主节点&#xff08;Master&#xff09;全权负责集群读写核心请求处理&#xff0c;从节点&#xff08;Slave&#xff09;仅专注于实时同步主节点数据&…...

观察使用TaotokenTokenPlan后项目月度AI成本的变化趋势

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察使用Taotoken TokenPlan后项目月度AI成本的变化趋势 对于许多采用按量计费模式的中小型项目而言&#xff0c;大模型API的月度支…...

【免费下载】 慧荣SM2258XT开卡工具集合

慧荣SM2258XT开卡工具集合 【下载地址】慧荣SM2258XT开卡工具集合 本仓库提供了一套专门针对慧荣SM2258XT主控的固态硬盘、移动硬盘及SSDM.2硬盘的开卡工具集合。该工具集合旨在解决因主控问题导致的设备无法识别、不识别或容量显示错误等问题。通过使用本工具包&#xff0c;您…...

从Educoder到真实项目:新手用Python处理用户输入的3个避坑点与最佳实践

从Educoder到真实项目&#xff1a;Python用户输入处理的3个避坑指南与工程实践 当你在Educoder上完美运行input()函数时&#xff0c;是否思考过这段代码在真实项目中可能引发的灾难&#xff1f;教学平台的理想环境与真实世界的复杂输入之间存在巨大鸿沟。本文将揭示那些在线练习…...

JDBC(四):Statement

Statement作用&#xff1a;执行sql1. 执行dml、ddlint excuteUpdate(sql)&#xff08;1&#xff09;dml&#xff0c;输出受影响行数&#xff08;为正&#xff0c;执行成功&#xff1b;为负&#xff0c;执行失败&#xff09;&#xff08;2&#xff09;ddl&#xff0c;可能输出0&…...

别再为导入报错发愁了!手把手教你用Parasolid格式把SolidWorks模型完美导入Adams(附常见错误排查)

从SolidWorks到Adams的模型导入实战指南&#xff1a;避坑技巧与深度解析 在工程仿真领域&#xff0c;SolidWorks和Adams的组合堪称黄金搭档——前者负责精确建模&#xff0c;后者专精多体动力学分析。但这对"黄金组合"的第一次握手往往让工程师们抓狂&#xff1a;模型…...