图论 (Java) 从入门到入土 /第一部分 图的基础-图的定义/

零.前言

        图,是一种比较复杂的数据结构。和树的一个节点只和上层一个节点相连不同,在图中,任意两个节点都可能相连,且可能具有方向性,并且节点的边具有权重,因此,图被用于描述各种复杂的数据对象,在自然科学、社会科学和人文科学等诸多领域有着非常广泛的应用。

        图论中一些经典的需要解决的问题有:图的遍历、图的连通性、图的判圈(环路检测)、最短路径、拓扑排序、最小生成树、网络流、二部图等。

        图论中一些经典的需要掌握的算法有:DFS、BFS、并查集、Dijkstra、Floyd、Prim、Kruskal等,需要了解并掌握,都是经常食用的算法。

        本系列的文章分为三个大的部分,包括图论基础,图的算法以及图的典型题目,此大部分是图的基础,包括图的整体定义,图的相关定义和图的表示,本文是有关于图的定义,主要是图的整体定义和图的相关定义。

一.图的基础

1.图的整体定义

 定义:图(Graph),由节点和边构成的一种集合,通常表示为G=(V,E),其中,V是节点,E是边,下图是一个典型的图的案例。

2.图的相关定义

节点(顶点)/  VerticesV=\left \{v_{1},v_{2}, v_{3}...v_{n} \right \}是节点(顶点)所构成的集合,下图中v{_{1}}是一个典型的节点。

边 / Edegs: E=\left \{ e_{(1,2)} ,e_{(1,3)},...,e_{(i,j)}\right \}是边构成的集合,下图e{_{1,3}}是一个典型的边。

无向图(双向) / Undirected Graph:边没有方向,也可以说双向图,即边的两个节点互通。

 

有向图 / Directed Graph:边有方向,e_{1,2}e_{2,1}是两个不同的边,下图是一个典型的有向图。

有权图 / Weighted Graph:边有权重,下图是一个典型的有权图。在有权图中,边的权重可以想象成长度,也可以看成宽度,根据具体题目可以是不同单位不同概念的权重。

无权图 / Unweighted Graph:  边没有权重,默认都可以看作权重为1,下图是一个典型的无权图。

无向无权图 / Undirected Unweighted Graph: 边无向,边没有权重,下图是一个典型的无向无权图。

无向有权图 / Directed Weighted Graph: 边无向,边有权重,下图是一个典型的无向有权图。

有向无权图 / Directed Unweighted Graph: 边有向,边没有权重,下图是一个典型的有向无权图。

有向有权图 / Directed Weighted Graph: 边有向,并且边有权重,下图是一个典型的有向有权图。

度 / Degree:对节点来说,和几个节点相邻,度就是多少,在下图中,节点v{_{1}}的度为3. 

入度 / Indegree:在有向图中,有几个边指向自己,入度就是多少, 在下图中,节点v{_{1}}的入度为1. 

出度 / Outdegree:在有向图中,自己指向几个节点,出度就是多少, 在下图中,节点v{_{1}}的出度为2. 

路径 / Path:在图中,从一节点到另一节点经过的边(边的数量可为0,即从一节点到节点本身),在下图中,\left \{e_{1,3},e_{3,4} \right \}构成从v_{1}v_{4}的一条路径。

路径长度 / Path Length:无权图中的路径单位之和(无权图默认为1),有权图中的路径权重之和,在下方两张图中,从节点v_{1}v_{4}的共色路径,无权图路径长度为2单位,有权图路径长度为5,那么在有向图中,我们的路径不一定存在,即无路径,比如在下图中,从v_{1}v_{5}没有路径可以到达。

简单路径 / Simple Path:路径上没有重复节点,对于下图的从v_{1}v_{2}两条路线来说,红色线路是简单路径,而蓝色路线不是简单路径。

最短路径 / Shortest Path:从一节点到另一节点所有可能的路径中最短的。在下图有向有权图中,从v_{1}v_{4}的所有可能路径中,最短路径为2。

 

圈/环 Cycle/Loop:从一节点出发,回到本身,路径长度大于一个单位长度(通常从一个节点出发不经过任一路径,回到本身,通常不叫作圈/环),下图为一个圈/环。若从一节点出发,经过一个单位路径回到本身,期间不经过其他节点,通常被叫做伪图,即伪图的一个节点可以通过一条边和自己相连,下下图为一个伪图。

 

简单回路/简单环 Simple Cycle/Loop:从一节点出发,回到本身,期间不算起始节点和终节点的路径上,不包含重复节点,下图为一个简单回路。

完全图 / Complete Graph:图中的每一个节点与其他节点都相互连接,下图为一个典型的完全图。

子图 / Subgraph:对于一个图的所有节点和边都属于另外一个图的一部分,在下图中,右方的图为左图的一个子图。

稠密图 / Dense Graph:一个图接近完全图。

稀疏图  / Sparse Graph:边很少的图,下图展示了一个稠密图和一个稀疏图。

连通 / Connected:从一个节点沿着存在的路径可以到达另一个节点,称这两个节点是连通的,下图的v_{1}v_{2}是连通的,而v_{1}v_{5}是不连通的。

 

连通图 / Connected Graph:任意两节点之间连通的图称为连通图,下图左边和右边分别为一个连通图和一个非连通图,对于连通图来讲,连通分量就是它本身。

连通分量 / Connected Component:对于无向图而言,一个极大连通子图为一个连通分量。所有连通分量构成互相没有相同顶点的子图集合,在下图中,连通分量\left \{ v_{1},v_{2},v_{3},v_{4} \right \}和连通分量v_{5}构成子图集合。

强连通图 / Strongly Connected:对于有向图而言,任意两个节点之间有能到达的路径,则是强联通图。 

强连通分量 / Strongly Connected Component:有向图的极大强连通子图称为强连通分量,下图展现了一个非强连通图的两个连通分量。

弱连通 / Weakly Connected:有向图不是强连通的,但其基础图是连通的,则称该有向图是弱连通的。

*以上的概念较为口语,并且个别定义可能有所出入,若读者想要更精细更科学的定义概念,可参考如下来源

{Ref.[1]},{Ref.[2]},{Ref.[3]}

邻接,邻接点,邻接边,邻接表,邻接矩阵,单元最短路(将在下文,图的表示中呈现)

参考来源Ref.

[1] 数据结构与算法(JAVA语言版)Adam Drozdek

[2] 数据结构与算法(JAVA版)罗文劼,王苗,张小莉

[3] leetcode yukiyama 图论算法从入门到放下 

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

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

相关文章

Docker基础知识全解析

​ Docker是一个开源的容器化平台,可以让开发者在容器中构建、打包、运行和发布应用程序,从而实现应用程序的快速部署和可移植性。Docker将应用程序和依赖项打包在一个轻量级的可移植容器中,这个容器可以在任何平台上运行,不会受到…

外卖app开发流程全解析

外卖app开发是现代餐饮业的一个必备部分。在这个数字化时代,人们更愿意使用手机应用程序来订购食品。因此,为了满足客户需求,餐饮企业需要开发自己的外卖app。 第一步:确定目标受众 在开始外卖app的开发之前,需要确定…

华为C++研发工程师编程题 ACM模式输入输出|| 1.汽水瓶,2.明明的随机数,3.进制转换

C ACM输入输出 1.汽水瓶题目描述思路代码如下 2.明明的随机数题目描述思路:代码如下: 3.进制转换题目描述思路:代码如下 题目链接: 华为研发工程师编程题 1.汽水瓶 题目描述 某商店规定:三个空汽水瓶可以换一瓶汽水…

完整数据分析体系概述

一、建设的出发点 满足业务需求,是建设数据分析体系的出发点,也是最终目的和最高要求。要注意的是,“业务需求”并没有统一的标准。不同部门,不同身份的人,需求是不一样的。从大的方面看,可以分作三个层级…

云计算服务安全评估办法

云计算服务安全评估办法 2019-07-22 14:46 来源: 网信办网站【字体:大 中 小】打印 国家互联网信息办公室 国家发展和改革委员会 工业和信息化部 财政部关于发布《云计算服务安全评估办法》的公告 2019年 第2号 为提高党政机关、关键信息基础设施运营者…

云原生CAx软件: HTTP基础知识汇总

随着云原生(Cloud Native)的兴起,面向服务架构(Service-Oriented Architecture,SOA)、微服务(Microservice)、容器(Container)等相关概念与技术正在逐渐影响CAx(CAD/CAE/CAM)软件的架构设计与开发。 在云原生CAx软件中,首先需要把系统按照功…

六、CANdelaStudio入门-通信参数编辑

本专栏将由浅入深的展开诊断实际开发与测试的数据库编辑,包含大量实际开发过程中的步骤、使用技巧与少量对Autosar标准的解读。希望能对大家有所帮助,与大家共同成长,早日成为一名车载诊断、通信全栈工程师。 本文介绍CANdelaStudio的通信参数编辑,欢迎各位朋友订阅、评论,…

heic格式转化jpg的3种好用方法

如果你是使用iOS手机的用户,那么一定对HEIC格式不陌生。虽然HEIC格式可以保存原始图像质量,但它只能在苹果手机或Mac电脑上打开。如果我们想要在安卓或Windows系统上打开,就需要使用转换软件将HEIC格式转换成常用的JPG格式。HEIC 是一种新型的…

H.264/AVC加密----选择加密

文献学习: 《Data Hiding in Encrypted H.264/AVC Video Streams by Codeword Substitution》 期刊:IEEE TRANSACTIONS ON INFORMATION FORENSICS AND SECURITY 简介 通过分析H.264/AVC编解码器的特性,提出了三个敏感部分(IPM、MVD和残差系…

深度学习-第R2周——LSTM火灾温度预测

深度学习-第R2周——LSTM火灾温度预测 深度学习-第R2周——LSTM火灾温度预测一、前言二、我的环境三、前期工作1、导入数据集2、数据可视化 四、构建数据集1、设置x,y2、归一化3、划分数据集 五、构建模型六、模型训练1、编译2、训练 七、评估1、loss图2、预测 深度学习-第R2周…

区间DP (Java) 解析/模板/案例

一. 区间DP简单介绍 区间DP,是经常会用到的、解决区间问题的一种方法,经常以动态规划(dfs/记忆化搜索)的形式展现,最核心的思想就是枚举区间(枚举端点),寻找切割点,处理因…

并发编程基石:管程

大家好,我是易安! 如果有人问我学习并发并发编程,最核心的技术点是什么,我一定会告诉他,管程技术。Java语言在1.5之前,提供的唯一的并发原语就是管程,而且1.5之后提供的SDK并发包,也…

手写Spring框架---IOC容器实现

目录 框架具备的最基本功能 实现容器前奏 创建注解 提取标记对象 extractPacakgeClass里面需要完成的事情 获取项目类加载器的目的 为什么不让用户传入绝对路径 类加载器ClassLoader 统一资源定位符URL ClassUtil提取标记类 获取包下类集合 装载目标类的集合 获取…

【Unity入门】21.预制体

【Unity入门】预制体 大家好,我是Lampard~~ 欢迎来到Unity入门系列博客,所学知识来自B站阿发老师~感谢 (一)预制体制作 (1)什么是预制体 这一章节的博客,我们将会学习一个预制体的概念。什么是…

【C语言】struct结构体

文章目录 一. 结构体简述二. 结构体的声明和定义1、简单地声明一个结构体和定义结构体变量2、声明结构体的同时也定义结构体变量3、匿名结构体4、配合typedef,声明结构体的同时为结构体取别名5、在声明匿名结构体时,使用typedef给这个匿名结构体取别名 三…

中国的chatGpt-中国chatGPT软件

chatGPT中文免费版 您是否在寻找一款免费且实用的聊天软件来更好地与别人交流?那么,“chatGPT中文免费版”将是您的不二选择! 作为一款由 OpenAI 训练的大型语言模型,chatGPT 中文免费版可以让您轻松地与其他人进行交流&#xf…

( 栈和队列) 155. 最小栈 ——【Leetcode每日一题】

❓155. 最小栈 难度:中等 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。…

计算机网络【2】 子网掩码

学习大佬记下的笔记 https://zhuanlan.zhihu.com/p/163119376 "子网"掩码,顾名思义,它就是拿来划分子网的,更准确的说,划分子网的同时,还能通过它知道主机在子网里面的具体ip的具体地址。 子网掩码只有一个…

Pytest接口自动化测试实战演练

结合单元测试框架pytest数据驱动模型allure 目录 api: 存储测试接口conftest.py :设置前置操作目前前置操作:1、获取token并传入headers,2、获取命令行参数给到环境变量,指定运行环境commmon:存储封装的公共方法connect_mysql.p…

【计算机是怎么跑起来的】基础:计算机三大原则

【计算机是怎么跑起来的】基础:计算机三大原则 计算机的三个根本性基础1.计算机是执行输入,运算,输出的机器输入,运算,输出 2. 软件是指令和数据的集合指令数据 3. 计算机的处理方式有时与人们的思维习惯不同对计算机来…