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

news2024/12/23 3:27:16

零.前言

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

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

        图论中一些经典的需要掌握的算法有: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 图论算法从入门到放下 

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

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

相关文章

python:tkinter 生成 buttonBar 示例

tk_test1.py # -*- coding: utf-8 -*- import os import tkinter as tk from tkinter import filedialogroot tk.Tk() root.title("生成 buttonBar 示例 ") var tk.StringVar() # 动态字符串 label tk.Label(root, textvariablevar) listbox tk.Listbox(root, s…

题集-快慢指针的应用(链表)

1.中心结点 代码: /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/struct ListNode* middleNode(struct ListNode* head) {if(head->nextNULL) return head;struct ListNode* fast head,*slow …

初阶数据结构——顺序表和链表(单链表)

目录 1.线性表2.顺序表SeqList.hSeqList.cTest.c数组习题移除元素删除有序数组中的重复项合并两个有序数组 顺序表的问题及思考 3.链表SList.hSList.cTest.c 1.线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中…

BI技巧丨计算组折线图

PowerBI中,通常我们会使用折线图来展示数据的趋势情况。但是当数据类别过多的时候,需求也在进一步深入,往往还需要我们将用户关注的重要节点标注出来,例如:最大值和最小值。 很早之前,白茶曾经写过一篇关于…

HTML学习笔记一

目录 HTML学习笔记 一、HTML标签 1、HTML语法规范 1.1标签的语法概述 1.2标签关系 2、HTML基本结构标签 2.1第一个HTML 2.2基本结构标签总结 3、开发工具 4、HTML常用标签 4.1标签的语义 4.2标题标签 4.3段落和换行标签 4.4文本格式化标签 4.5div和span标签 4.…

Linux云服务器的使用,以及运行Python程序、相关Linux指令

目录 1、使用Linux云服务器的软件 2、Linux系统运行Python程序 3、Linux系统查看包、虚拟环境、安装包等 以下几个深度学习服务器都不错:智星云、AutoDL、恒源云 1、使用Linux云服务器的软件 MobaXterm_Personal 推荐MobaXterm_Personal mobaxterm是一款方便网站…

基于Flask的留言板的设计与实现

这是《Flask Web开发实战:入门、进阶与原理解析》这本书中的一个小项目,我在学习后根据书中的教程实现了留言板的功能,并结合我的思路将代码做了一些调整。 下面这是实现后的展示图片 文章目录 设计思路项目代码exts.pymodels.pyforms.pyerrors.pycomma…

DMDTS:DM迁移到SQL脚本

DMDTS:DM迁移到SQL脚本 环境介绍1 注册工程2 新建迁移3 迁移工具介绍4 选择迁移方式5 配置数据源6 配置SQL脚本文件7 配置源端获取对象方式和迁移策略8 选择指定对象复制9 选择迁移对象9.1 迁移对象的配置 - - 转换 设置表的映射关系 10 审阅迁移任务11 完成迁移 环境介绍 DM管…

一文了解使用Moonbeam原生跨链的潜力项目

跨链互连合约是Moonbeam独特的原生跨链解决方案,不仅帮助开发团队在Moonbeam网络即可解锁不同公链的特色功能,而且各类去中心化应用的终端使用者能因此获得更便捷安全的跨链体验。 Moonbeam的原生跨链解决方案包含Polkadot生态、不同异构链和Moonbeam生…

hitcontraining_uaf

1,三连 基本信息:x86-32-el,堆题思路; 保护:Partial RELRO。 堆题多看一个Libc: 2,IDA分析 main功能: add_note()功能: malloc了两次: 8字节填充(利用点之一&#xf…

Markdown快速入门教程

Markdown 的目标是实现「易读易写」,并强调它的「可读性」,因此Markdown 的语法全由标点符号所组成,并经过严谨慎选,是为了让它们看起来就像所要表达的意思;以下是Markdown 大部分的语法。 常用语法- 文字样式 文字字…

Allegro过孔盖油和过孔开窗设置(部分过孔开窗)

Allegro设置一部分过孔盖油,另一部分过孔开窗。 过孔开窗:过孔部分去除阻焊,便于调试和散热; 过孔盖油:过孔盖上阻焊油墨,防止过孔连锡短路。 总结 使用pad designer设计两种via pad,一种不开…

分布式事务的几种解决方案

一.基础概念 1. 什么是事务 事务可以看做是一次大的活动,它由不同的小活动组成,这些活动 要么全部成功, 要么全部失败 2.本地事务 在计算机系统中,更多的是通过 关系型数据库来控制事务,这是利用数据库 本身的事务特性…

基于Qt的教务管理系统的设计与实现

获取代码: (1) 下载链接: https://download.csdn.net/download/kese7952/87741551 (2) 添加博主微信获取,备注来源: mryang511688 项目描述 技术:C、QT等 摘要: 随着学校规模的不断扩大,学生的流动变迁导致了学校在管理学生信息…

二叉堆(Binary Heap)

二叉堆(Binary Heap) 二叉堆概述优先级队列 二叉堆(Binary Heap)其实比较简单,但却非常有用,常见的应用二叉堆排序和优先级队列。本文将介绍二叉堆的基本性质、基本操作和二叉堆在优先级队列上的应用。 二…

abc 283E 经典dp

题意&#xff1a;https://www.luogu.com.cn/problem/AT_abc283_e 思路&#xff1a;非常经典的dp&#xff0c;设为前i行第i行是否反转和第i1行是否反转。 /*keep on going and never give up*/ #include<cstdio> #include<iostream> #include<queue> #inclu…

【Mysql】基础篇:DDL (data definition language) 总结

博主简介&#xff1a;努力学习的大一在校计算机专业学生&#xff0c;热爱学习和创作。目前在学习和分享&#xff1a;数据结构、Go&#xff0c;Java等相关知识。博主主页&#xff1a; 是瑶瑶子啦所属专栏: Mysql从入门到精通近期目标&#xff1a;写好专栏的每一篇文章 目录 一、…

pytest自动化框架之allure测试报告的用例描述设置

allure测试报告的用例描述相关方法&#xff1b;如下图 allure标记用例级别severity 在做自动化测试的过程中&#xff0c;测试用例越来越多的时候&#xff0c;如果执行一轮测试发现了几个测试不通过&#xff0c;我们也希望能快速统计出缺陷的等级。 pytest结合allure框架可以对…

Linux基础指令大讲解

文章目录 1.linux的历史2.如何安装linux3.如何创建和删除用户4.目录&#xff0c;文件&#xff0c;文件夹区别5.pwd6.ls6.1基础语法6.2常用选项 7.alias 和 which的配套使用7.1基础格式7.2解释7.3与其关联的一些命令 8.cd8.1相对路径和绝对路径8.2运行可执行程序的方法8.3cd的基…

Java学习(韩顺平670-675)

目录 在我看来&#xff0c;我们在Java需要不断封包的原因就是为了使用不同类库中自己所需的方法&#xff0c;我们才要进行封装的&#xff0c;你怎么看&#xff1f; 你好&#xff0c;什么叫做关闭外层流 关于字符流要求 服务端/客户端 TCP网络通信编程//●//应用案例4 TCPFil…