【数据结构】图的简介(图的逻辑结构)

一.引例(哥尼斯堡七桥问题)

        哥尼斯堡七桥问题是指在哥尼斯堡市(今属俄罗斯)的普雷格尔河(Pregel River)中,是否可以走遍每座桥一次且仅一次最后回到起点的问题。这个问题被认为是图论的开端,也是数学史上著名的问题之一。

        欧拉在解决这个问题时,将问题转化为了图论中的欧拉回路问题。他证明了如果一个图中有欧拉回路,那么这个图中每个顶点的度数都是偶数。反之,如果每个顶点的度数都是偶数,那么这个图中就存在欧拉回路

        因此,哥尼斯堡七桥问题的答案是否定的,因为哥尼斯堡的地图中有两个岛屿,这两个岛屿与其他地区相连的桥的数量都是奇数,因此这个图中不存在欧拉回路。

二.图的逻辑结构

1.图的定义

图是由顶点的有穷非空集合和顶点之间边的几何组成。

通常表示为:G=(V,E)

注:

1)G表示一个图

2)V是图G中顶点的集合

3)E是图G中顶点之间边的集合

4)在线性表中,元素的个数可以为0,称之为空表;在树中,元素的个数可以为0,称之为空树;但是在图中,顶点个数不能为0,可以没有边。

2.有向图与无向图

若顶点vi和vj之间的边没有方向,则称这条边为无向边,表示为(vi,vj)

如果图的任意两个顶点之间的边都是无向边,则称该图为无向图。

若顶点vi和vj之间的边有方向,则称这条边为有向边,表示为<vi,vj>

如果图的任意两个顶点之间的边都是有向边,则称该图为有向图。

3.图的基本术语

1)简单图

在图中,若不存在顶点到自身的边,且同一条边不重复出现。

注:数据结构中讨论的都是简单图

2)邻接/依附

无向图中,对于任意两个顶点vi和vj,若存在边(vi,vj),则称顶点vi和顶点vj互为邻接点,同时称边(vi,vj)依附于顶点vi和顶点vj。

有向图中,对于任意两个顶点vi和vj,若存在弧<vi,vj>,则称顶点vi邻接到顶点vj,顶点vj邻接自顶点vi,同时称弧<vi,vj>依附于顶点vi和顶点vj。

3)无向完全图/有向完全图

无向完全图:

在无向图中,如果任意两个顶点之间都存在边,则称该图为无向完全图。

含有n个顶点的无向完全图中边的个数:

n*(n-1)/2

有向完全图:

在有向图中,如果任意两个顶点之间都存在方向相反的两条弧,则称该图为有向完全图。

含有n个顶点的有向完全图中边的个数:

n*(n-1)

4)稀疏图/稠密图

稀疏图:边数很少的图

稠密图:边数很多的图

5)度

无向图:TD(v)

入度:ID(v)

出度:OD(v)

6)度与边数的关系

所有顶点的度之和=边数*2

入度=出度=边数

7)权/网

权:对边赋予的有意义的数值量

(从一个顶点到另一个顶点所需要付出的代价)

网:边上带权的图

8)路径长度

非带权图:边的个数

带权图:各边权之和

9)简单回路

除了第一个顶点和最后一个顶点外,其余顶点不重复出现的回路。

10)连通图

图中任意两个顶点都是联通的

11)连通分量

非连通图的极大连通子图

12)强连通图

在有向图中,堆图中任意一对顶点vi和vj(i!=j),若从顶点vi到顶点vj和从顶点vj到顶点vi均有路径

13)生成树

n个顶点的连通图G的生成树是包含G中全部顶点的一个极小连通子图

含有n-1条边

生成树不是唯一的

14)生成森林

在非连通图中,由每个连通分量都可以得到一棵生成树,这些连通分量的生成树就组成了一个非连通图的生成森林。

4.不同结构中逻辑关系的对比

在线性结构中,数据元素之间仅具有线性关系。

在树结构中,结点之间具有层次关系。

在图结构中,任意两个顶点之间都可能有关系。

在线性结构中,元素之间的关系为前驱和后继。

在树结构中,结点之间的关系为双亲和孩子。

在图结构中,顶点之间的关系为邻接。

三.图的抽象数据类型定义

ADT Graph

Data

        顶点的有穷非空集合和边的集合

Operation

初始

销毁

深度优先搜索

广度优先搜索

 

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

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

相关文章

安全知识普及:什么是垃圾邮件和网络钓鱼欺诈

文章目录 什么是垃圾邮件&#xff1f;如何保护您自己免遭垃圾电子邮件和网络钓鱼侵害区分私人和公用电子邮件私人电子邮件公共电子邮件 使用反垃圾邮件过滤器推荐阅读 什么是垃圾邮件&#xff1f; 您的邮箱里经常会出现一些莫名其妙的邮件&#xff0c;而这就是电子形式的垃圾邮…

早晨暖心的早安问候语,祝好心情从清晨开始,愿你享受美好生活每一天!

1、冬天里&#xff0c;重调理&#xff1b;多锻炼&#xff0c;日光浴&#xff1b;早安睡&#xff0c;晚游历&#xff1b;勤开窗&#xff0c;通空气&#xff1b;暖腹背&#xff0c;寒不欺&#xff1b;适滋补&#xff0c;强体力&#xff1b;心乐观&#xff0c;无忧虑&#xff1b;温…

Java学习之路 —— 网络通信

文章目录 1. InetAddress2. UDP3. TCP4. 总结 1. InetAddress InetAddress的常用方法如下&#xff1a; public class InetAddressDemo {public static void main(String[] args) throws Exception{// 1. 获取本机IP地址对象InetAddress ip1 InetAddress.getLocalHost();Sys…

车间ERP管理系统都有哪些?能带给企业什么好处

不同规模的制造企业有不同的管理模式和经营策略&#xff0c;而生产和销售等业务是这类企业较为核心的部门&#xff0c;其中车间的管理是生产过程管理的重点环节之一。 车间的管理工作涉及物料、班组、设备、工时评估、生产现场数据采集、派工单、退补料等环节&#xff0c;如何…

2023年(第六届)电力机器人应用与创新发展论坛-核心PPT资料下载

一、峰会简介 大会以“聚焦电力机器人创新、助力行业数字化转型、促进产业链协同发展”为主题&#xff0c;展示电力机器人产业全景创新技术&#xff0c;探讨数字化战略下电力机器人应用前景和发展趋势。为加快推进电力机器人应用拓新&#xff0c;助力电网数字化转型升级&#…

吴恩达《机器学习》9-1:代价函数

一、引入新标记方法 首先&#xff0c;引入一些新的标记方法&#xff0c;以便更好地讨论神经网络的代价函数。考虑神经网络的训练样本&#xff0c;其中每个样本包含输入 x 和输出信号 y。我们用 L 表示神经网络的层数&#xff0c;表示每层的神经元个数&#xff08;表示输出层神…

C语言青蛙爬井(ZZULIOJ1072:青蛙爬井)

题目描述 有一口深度为high米的水井&#xff0c;井底有一只青蛙&#xff0c;它每天白天能够沿井壁向上爬up米&#xff0c;夜里则顺井壁向下滑down米&#xff0c;若青蛙从某个早晨开始向外爬&#xff0c;对于任意指定的high、up和down值&#xff08;均为自然数&#xff09;&…

如何解決開機後出現BitLocker修復畫面/取得BitLocker金鑰

[Notebook/Desktop/AIO] 疑難排解 - 如何解決開機後出現BitLocker修復畫面/取得BitLocker金鑰 如果您遇到開機進入系統後出現BitLocker修復畫面&#xff0c;這表示您電腦的硬碟已受BitLocker保護(硬碟被鎖住)。當系統在維修以及其他因素下做過硬體變動或BIOS更新設置變動&…

工业机器人“智能制造产线6”教学案例

​智能制造单元主要以智能制造技术推广应用实际与发展需求为设计依据&#xff0c;按照“设备自动化生产精益化管理信息化人工高效化”的构建理念&#xff0c;将数控加工设备、工业机器人、检测设备、数据信息采集管控设备等典型加工制造设备&#xff0c;集成为智能制造单元“硬…

MIUI解锁BL

解锁BL锁会清空手机数据!!! 解锁工具下载: http://www.miui.com/unlock/download.html 解压运行.exe文件 注意点: 手机绑定的账号与解锁工具登录的账号应是同一个账号 在Fastboot界面, 一直无法显示连接手机 USB3.0接口的问题, 巨坑!!! 解决方案参考下面第二篇文章 参考文…

阿里云崩了,总结我们从云上搬到线下经历了什么

我们做钢铁行业云的时候&#xff0c;也曾购买过某讯的云服务器。当时某讯做活动&#xff0c;头3年比较便宜&#xff0c;大概买了40台左右云服务器。 但是&#xff0c;3年期间使用云服务器的经历&#xff0c;体验并不好&#xff1a;1.我们云服务器的密码都是随机生成的&#xff…

怎么使用Cpolar+Lychee搭建私人图床网站并实现公网访问?

文章目录 1.前言2. Lychee网站搭建2.1. Lychee下载和安装2.2 Lychee网页测试2.3 cpolar的安装和注册 3.本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4.公网访问测试5.结语 1.前言 图床作为图片集中存放的服务网站&#xff0c;可以看做是云存储的一部分&#xff0c;既可…

linuxTcp状态转换

1.TCP状态转换 在TCP进行三次握手&#xff0c;或者四次挥手的过程中&#xff0c;通信的服务器和客户端内部会发送状态上的变化&#xff0c;发生的状态变化在程序中是看不到的&#xff0c;这个状态的变化也不需要程序猿去维护&#xff0c;但是在某些情况下进行程序的调试会去查…

goland 远程调试 remote debug

1、远程服务器装好go环境&#xff0c;并设置国内源 linux go安装 参考&#xff1a; 如何在 Debian / Ubuntu 上安装 Go 开发环境 - 知乎 设置国内源 go env -w GOPROXYhttps://goproxy.cn,direct 2、远程服务器安装dlv git clone https://github.com/derekparker/delve.gi…

基于单片机体温脉搏检测控制系统及源程序

一、系统方案 1、本设计采用51单片机作为主控器。 2、DS18B20传感器检测体温。 3、红外对接管采集心率值送到液晶1602显示。 二、硬件设计 原理图如下&#xff1a; 三、单片机软件设计 1、首先是系统初始化 /lcd1602初始化设置*/ void init_1602() { write_com(0x38); //显示…

【调研】通信原理课程虚拟教研室

项目来源 “十四五”教育发展规划有关部署&#xff1a;《教育部办公厅关于公布首批虚拟教研室建设试点名单的通知》&#xff08;教高厅函〔2022〕2号&#xff09;“虚拟教研室建设” 新任务&#xff1a;创新教研形态、加强教学研究、共建优质资源、开展教师培训等重点任务交流…

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层

&#x1f47b;如图&#xff0c;我现在有一组经纬度点位Point&#xff0c;接下来我们将他装换为多边形Polygon格式 &#x1f47b;使用QGIS > 图层 > 添加图层 > 添加分隔文本图层 > 打开这个csv点位文件 &#x1f47b;打开后如左下图&#xff0c;csv文件中的四个点位…

【uniapp】Google Maps

话不多说 直接上干货 提前申请谷歌地图账号一、新建地图 使用h5获取当前定位或者使用三方uniapp插件 var coords ""navigator.geolocation.getCurrentPosition(function(position) {coords {lat: position.coords.latitude,lng: position.coords.longitude};lats …

Linux入门(三)

Linux grep 命令 1&#xff1a; 作用 ​ grep是一种文本搜索工具&#xff0c;它能使用特定的搜索模式&#xff0c;包括[正则表达式]搜索文本&#xff0c;并默认输出匹配行。 ​ windows类似的命令是findstr. 2&#xff1a;语法 grep -options&#xff08;参数&#xff09;…

【OpenAI开发者大会,全新大模型它来了,价格大跌...】

继今年春天发布 GPT-4 之后&#xff0c;OpenAI 又创造了一个不眠夜。 过去一年&#xff0c;ChatGPT 绝对是整个科技领域最热的词汇。 北京时间 11 月 7 日凌晨 02:00&#xff0c;OpenAI 的首次 DevDay 开发者日活动正式开始。Keynote 主论坛环节由 Sam Altman 主讲并在油管现…