图的基本术语——非八股文

        我之前只看到了数据结构与算法的冰山一角感觉这些术语只会让知识越来越难理解,现在来看,他们完美抽象一些概念和知识,非常重要。

        本篇概念肯定总结不全,只有遇到的会写上,持续更新,之前文章已经提过的如并查集、最短路径、邻接表等不再重复,这里为补充。


        图形结构中的元素之间存在多对多的联系。

        图形结构中,每一个元素前驱结点可以有多个,后继结点也可以有多个。    

         首先我们肯定都知道图可以分为有向图无向图,它们各自有一些独属于自己的术语和共同的术语,下面这个思维导图帮大家理清一些概念:  


共同术语 

我们先从共同的概念说起 :

  • 完全图:针对有向图无向图,每两个顶点都有一条边(有向图至少 n(n-1) 条边,无向图至少\frac{n(n-1)}{2}条边),如图所示。

  • 稀疏图与稠密图 :根据概念来说,有很少条边或弧(如 e<nlog_2n ,其中e为边的数目,n为顶点的个数)。需要注意的的是,因为这两个概念常用于选择邻接矩阵或邻接表,具体选用要与算法结合。
  • 权和网:权和网可以理解为带权图,在绝大数应用中,每条边应该是带有权重的,权可以表示从一个顶点到另一个顶点的距离、时间或代价等含义。
  • 邻接点:无向图中邻接点是没有方向的,或者称为对称的,假若顶点v 和顶点w 之间存在一条边, 则称顶点v 和w 互为邻接点。在有向图中,邻接点是有方向的,如果存在从顶点到顶点的有向边,那么我们说顶点是顶点的出边邻接点,顶点是顶点的入边邻接点。

无向图

  • 连通:两个顶点有路径。
  • 连通图:任意两个顶点有路径,但不一定都有边。
  • 连通分量:指在无向图中的极大连通子图,如图中的无向非连通图有两个连通分量。

  • 度:顶点v的度是指和v相关联的边的数目;如图中,顶点v的度为3。

有向图

  • 强连通图:任意两个顶点有路径,但不一定都有边。(注意并不一定两个顶点V_iV_j有两条边,只要可以形成环就行。)完全有向图肯定就是强连通图。
  • 强连通分量:有向图中的极大强连通子图称作有向图的强连通分量,如图所示的有向非强连通图有两个强连通分量。

  • 出度和入度:对于有向图,顶点v的度被分为出度和入度,入度是以顶点v为头的的弧数目(箭头指向v),出度就是以顶点v为尾的的弧数目。顶点v的入度为1,出度为2。 

压缩存储

        压缩存储是指在不丢失数据信息的前提下,对数据进行重新编码或组织,以减少数据所占用的存储空间的方法。通过特定的算法和数据结构,将原始数据转换为一种更紧凑的表示形式,在需要使用数据时再进行解压缩还原。

        这里主要介绍矩阵的压缩存储。

        对称矩阵

        即a_{i j}=a_{j i},首先我们先回顾一个等差数列的公式:1+2+3+...+n=\frac{n(n+1)}{2}

根据这个公式,我们就可以把一个n维矩阵,用一个一维数组进行存储了。无向图的邻接矩阵就是对称矩阵可用一维数组压缩储存。 

        可以按行主序即下三角存储;或者按列主序即上三角存储。如果我们要找矩阵中位置第i行第j列的元素a_{ij},还是利用上面等差数列公式按行存储和列存储即可搞定。

        三角矩阵

        三角矩阵即只有矩阵的一个三角的数字有意义,对称矩阵就可以理解为三角矩阵,所以三角矩阵的压缩储存与对角矩阵基本一样。

        对角矩阵

        就是只在对角线上存在的元素有意义。 一般分两种方式存储:行序存储和对角线。

        可以将主对角线元素存储在一个一维数组中,通过数组下标与矩阵主对角线元素的对应关系来实现对矩阵元素的访问和操作。例如,对于对角矩阵A的主对角线元素a_{ii},可以存储在一维数组B中,B[i] = a_{ii}

        其它

        另外稀疏矩阵的压缩存储可以用一个三元组表来表示稀疏矩阵中的非0元素。

        稀疏矩阵是指矩阵中绝大多数元素为 0,只有少数非 0 元素的矩阵。为了节省存储空间和提高运算效率,通常采用压缩存储的方式来存储稀疏矩阵,其中一种常见的方法就是用三元组表来表示稀疏矩阵中的非 0 元素。

        三元组表中的每个三元组通常表示为(行标,列标,值),分别记录了稀疏矩阵中每个非 0 元素所在的行、列位置以及该元素的值。通过这种方式,可以只存储稀疏矩阵中的非 0 元素,而不必像常规的二维数组存储方式那样为大量的 0 元素分配存储空间,从而达到压缩存储的目的。例如,对于一个稀疏矩阵:

        可以用三元组表表示为:{(1, 1, 1), (2, 3, 3), (4, 2, 4)}

        除了三元组表,压缩存储稀疏矩阵还可以使用十字链表等其他方法。

参考文献

稠密图与稀疏图判别 - 焓青 - 博客园

【数据结构】图的基本概念—无/有向图、权和网、完全图、路径与回路-阿里云开发者社区

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

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

相关文章

oracle: 表分区>>范围分区,列表分区,散列分区/哈希分区,间隔分区,参考分区,组合分区,子分区/复合分区/组合分区

分区表 是将一个逻辑上的大表按照特定的规则划分为多个物理上的子表&#xff0c;这些子表称为分区。 分区可以基于不同的维度&#xff0c;如时间、数值范围、字符串值等&#xff0c;将数据分散存储在不同的分区 中&#xff0c;以提高数据管理的效率和查询性能&#xff0c;同时…

【单层神经网络】基于MXNet的线性回归实现(底层实现)

写在前面 刚开始先从普通的寻优算法开始&#xff0c;熟悉一下学习训练过程下面将使用梯度下降法寻优&#xff0c;但这大概只能是局部最优&#xff0c;它并不是一个十分优秀的寻优算法 整体流程 生成训练数据集&#xff08;实际工程中&#xff0c;需要从实际对象身上采集数据…

本地快速部署DeepSeek-R1模型——2025新年贺岁

一晃年初六了&#xff0c;春节长假余额马上归零了。今天下午在我的电脑上成功部署了DeepSeek-R1模型&#xff0c;抽个时间和大家简单分享一下过程&#xff1a; 概述 DeepSeek模型 是一家由中国知名量化私募巨头幻方量化创立的人工智能公司&#xff0c;致力于开发高效、高性能…

C++11详解(一) -- 列表初始化,右值引用和移动语义

文章目录 1.列表初始化1.1 C98传统的{}1.2 C11中的{}1.3 C11中的std::initializer_list 2.右值引用和移动语义2.1左值和右值2.2左值引用和右值引用2.3 引用延长生命周期2.4左值和右值的参数匹配问题2.5右值引用和移动语义的使用场景2.5.1左值引用主要使用场景2.5.2移动构造和移…

在K8S中,pending状态一般由什么原因导致的?

在Kubernetes中&#xff0c;资源或Pod处于Pending状态可能有多种原因引起。以下是一些常见的原因和详细解释&#xff1a; 资源不足 概述&#xff1a;当集群中的资源不足以满足Pod或服务的需求时&#xff0c;它们可能会被至于Pending状态。这通常涉及到CPU、内存、存储或其他资…

手写MVVM框架-构建虚拟dom树

MVVM的核心之一就是虚拟dom树&#xff0c;我们这一章节就先构建一个虚拟dom树 首先我们需要创建一个VNode的类 // 当前类的位置是src/vnode/index.js export default class VNode{constructor(tag, // 标签名称&#xff08;英文大写&#xff09;ele, // 对应真实节点children,…

linux内核源代码中__init的作用?

在 Linux 内核源代码中&#xff0c;__init是一个特殊的宏&#xff0c;用于标记在内核初始化阶段使用的变量或函数。这个宏的作用是告诉内核编译器和链接器&#xff0c;被标记的变量或函数只在内核的初始化阶段使用&#xff0c;在系统启动完成后就不再需要了。因此&#xff0c;这…

【大数据技术】教程03:本机PyCharm远程连接虚拟机Python

本机PyCharm远程连接虚拟机Python 注意:本文需要使用PyCharm专业版。 pycharm-professional-2024.1.4VMware Workstation Pro 16CentOS-Stream-10-latest-x86_64-dvd1.iso写在前面 本文主要介绍如何使用本地PyCharm远程连接虚拟机,运行Python脚本,提高编程效率。 注意: …

pytorch实现门控循环单元 (GRU)

人工智能例子汇总&#xff1a;AI常见的算法和例子-CSDN博客 特性GRULSTM计算效率更快&#xff0c;参数更少相对较慢&#xff0c;参数更多结构复杂度只有两个门&#xff08;更新门和重置门&#xff09;三个门&#xff08;输入门、遗忘门、输出门&#xff09;处理长时依赖一般适…

PAT甲级1032、sharing

题目 To store English words, one method is to use linked lists and store a word letter by letter. To save some space, we may let the words share the same sublist if they share the same suffix. For example, loading and being are stored as showed in Figure …

最小生成树kruskal算法

文章目录 kruskal算法的思想模板 kruskal算法的思想 模板 #include <bits/stdc.h> #define lowbit(x) ((x)&(-x)) #define int long long #define endl \n #define PII pair<int,int> #define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0); using na…

为何在Kubernetes容器中以root身份运行存在风险?

作者&#xff1a;马辛瓦西奥内克&#xff08;Marcin Wasiucionek&#xff09; 引言 在Kubernetes安全领域&#xff0c;一个常见的建议是让容器以非root用户身份运行。但是&#xff0c;在容器中以root身份运行&#xff0c;实际会带来哪些安全隐患呢&#xff1f;在Docker镜像和…

js --- 获取时间戳

介绍 使用js获取当前时间戳 语法 Date.now()

ConcurrentHashMap线程安全:分段锁 到 synchronized + CAS

专栏系列文章地址&#xff1a;https://blog.csdn.net/qq_26437925/article/details/145290162 本文目标&#xff1a; 理解ConcurrentHashMap为什么线程安全&#xff1b;ConcurrentHashMap的具体细节还需要进一步研究 目录 ConcurrentHashMap介绍JDK7的分段锁实现JDK8的synchr…

Vue和Java使用AES加密传输

背景&#xff1a;Vue对参数进行加密&#xff0c;对响应进行解密。Java对参数进行解密&#xff0c;对响应进行解密。不拦截文件上传类请求、GET请求。 【1】前端配置 安装crypto npm install crypto-js编写加解密工具类encrypt.js import CryptoJS from crypto-jsconst KEY …

开发板目录 /usr/lib/fonts/ 中的字体文件 msyh.ttc 的介绍【微软雅黑(Microsoft YaHei)】

本文是博文 https://blog.csdn.net/wenhao_ir/article/details/145433648 的延伸扩展。 本文是博文 https://blog.csdn.net/wenhao_ir/article/details/145433648 的延伸扩展。 问&#xff1a;运行 ls /usr/lib/fonts/ 发现有一个名叫 msyh.ttc 的字体文件&#xff0c;能介绍…

[ESP32:Vscode+PlatformIO]新建工程 常用配置与设置

2025-1-29 一、新建工程 选择一个要创建工程文件夹的地方&#xff0c;在空白处鼠标右键选择通过Code打开 打开Vscode&#xff0c;点击platformIO图标&#xff0c;选择PIO Home下的open&#xff0c;最后点击new project 按照下图进行设置 第一个是工程文件夹的名称 第二个是…

述评:如果抗拒特朗普的“普征关税”

题 记 美国总统特朗普宣布对美国三大贸易夥伴——中国、墨西哥和加拿大&#xff0c;分别征收10%、25%的关税。 他威胁说&#xff0c;如果这三个国家不解决他对非法移民和毒品走私的担忧&#xff0c;他就要征收进口税。 去年&#xff0c;中国、墨西哥和加拿大这三个国家&#…

九. Redis 持久化-AOF(详细讲解说明,一个配置一个说明分析,步步讲解到位 2)

九. Redis 持久化-AOF(详细讲解说明&#xff0c;一个配置一个说明分析&#xff0c;步步讲解到位 2) 文章目录 九. Redis 持久化-AOF(详细讲解说明&#xff0c;一个配置一个说明分析&#xff0c;步步讲解到位 2)1. Redis 持久化 AOF 概述2. AOF 持久化流程3. AOF 的配置4. AOF 启…

C++11新特性之long long超长整形

1.介绍 long long 超长整形是C11标准新添加的&#xff0c;用于表示更大范围整数的类型。 2.用法 占用空间&#xff1a;至少64位&#xff08;8个字节&#xff09;。 对于有符号long long 整形&#xff0c;后缀用“LL”或“II”标识。例如&#xff0c;“10LL”就表示有符号超长整…