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

【图论】图的定义与一些常用术语

【图论】图的定义

1. 图是什么

图(graph)由节点(node)和边(edge)组成。其中,节点集合记为 VVV,边集合记为 EEE 。每条边连接两个节点,某些图的边可能具有方向性。集合元素的数量用该集合的绝对值来表示。
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
通过对比可以看出,图比树具有更大的灵活性。例如,树结构要求子节点不能与父节点直接相连且禁止横向连接,而图不仅允许任意节点间自由连接,还支持自环和方向定义。可以说树是图论中的一种特殊结构,或者说是一种受到严格限制的图。

2. 图的一些专用术语

2.1 边权

对于一些图的边会给出一个数值,这个值叫做边权(weight)。它可以表示为距离、过路费、障碍数量等各种各样的数值。
在这里插入图片描述

2.2 有向图与无向图

有向图是指有方向的图,只能沿着箭头方向移动,不能走回头路;而无向图则可以自由通行

2.3 路径与途径

从一点开始,中间经历不重复的边到另一个点中间的路叫路径(path
从一点开始,中间经历可重复的边到另一个点中间的路叫途径(waywalk

2.4 环、重边与自环

环:从一个点到它本身,序列长度至少为 222路径
重边:允许两个点之间有多条边
自环:允许边自己连向自己

2.5 度、入度和出度

度:用于无向图,与自己连接的边的条数
入度:用于有向图,以自己为终点的边的条数
出度:用于有向图,以自己为起点的边的条数

2.6 联通与连通分量

uuu 和点 vvv 连通:是否存在从点 uuu 到点 vvv 的路径
联通分量:与一个点连通的所有点构成的集合

2.7 弱连通与强连通

把有向边的方向忽略得到无向图,对应这个无向图中的连通、连通分量和连通图就是弱连通、弱连通分量和弱连通图;在有向图中,如果两个顶点之间至少存在一条路径,则称这两个顶点是强连通的。如果一个有向图中的任意两个顶点都是强连通的,则称该图为强连通图。对于非强连通图,其极大强连通子图被称为强连通分量

2.8 稀疏图与稠密图

图的稀疏性与稠密性主要取决于图中边的数量相对于顶点数量的密度。如果图中 ∣E∣≪∣V∣2|E| \ll |V|^2EV2,则这个图为稀疏图;若∣E∣≈∣V∣2|E| \approx |V|^2EV2,则此图为稠密图

2.9 四联通与八联通

这个用于字符迷宫上,例如对于任意一个位置,你可以上下左右移动,这就叫做四联通;如果你可以八方移动,就叫八联通

在编程实现中,一般会定义方向数组。

四方向数组:

const int DX[4] = {0, 1, 0, -1};
const int DY[4] = {1, 0, -1, 0};

八方向数组:

const int DX[8] = {-1, 1, 0, 0, -1, -1, 1, 1};
const int DY[8] = {0, 0, -1, 1, -1, 1, -1, 1};
http://www.dtcms.com/a/288721.html

相关文章:

  • RabbitMQ:解锁高效消息传递的密码[特殊字符]
  • UE为什么FlipFlop按快了会触发Bug?
  • 【愚公系列】《MIoT.VC》002-构建基本仿真工作站(布局一个基本工作站)
  • springboot注册servlet
  • Qt 应用程序入口代码分析
  • 彩虹云商城全源码 - 全新客服系统上线
  • 【实习总结】Qt中如何使用QSettings操作.ini配置文件
  • Qt视音频推流/监控推流/自动重连推流/推流同时保存录像文件到本地/网页打开webrtc预览
  • Docker 在 Ubuntu 系统中的详细操作指南
  • Qt--Widget类对象的构造函数分析
  • LockFile简要分析
  • 如何实战优化SEO关键词提升百度排名?
  • 前端的测试
  • C++中vector的iterator迭代器的理解
  • C++ 编译链接机制的演化路径
  • 牛客NC14893 栈和排序(贪心 + 栈 + 后缀最大值维护)
  • 【机器学习|学习笔记】详解支持向量机(Support Vector Machine,SVM)为何要引入核函数?为何对缺失数据敏感?
  • 深入解析Hadoop中的EditLog与FsImage持久化设计及Checkpoint机制
  • Hadoop小文件合并技术深度解析:HAR文件归档、存储代价与索引结构
  • LeetCode|Day20|9. 回文数|Python刷题笔记
  • IP协议介绍
  • Linux: rsync+inotify实时同步及rsync+sersync实时同步
  • Leetcode 710. 黑名单中的随机数
  • 使用 Pyecharts 绘制精美饼状图:从基础到高级技巧
  • PDF 编辑器:多文件合并 拆分 旋转 顺序随便调 加水印 密码锁 页码背景
  • 微服务雪崩防护最佳实践之sentinel
  • Java 大视界 -- Java 大数据在智能安防门禁系统中的权限动态管理与安全审计(353)
  • 嵌入式硬件篇---舵机(示波器)
  • 测试学习之——Pytest Day4
  • python中读取 Excel 表格数据