图论——基础概念

news2025/2/23 12:01:51

文章目录

  • 学习引言
  • 什么是图
  • 图的一些定义和概念
  • 图的存储方式
    • 二维数组邻接矩阵存储
      • 优缺点
    • 数组模拟邻接表存储
      • 优缺点
    • 边集数组优缺点
    • 排序前向星优缺点
    • 链式前向星优缺点


学习引言

图论,是 C++ 里面很重要的一种算法,今天,就让我们一起来了解一下图论吧!

如果对您有帮助,就点个赞吧!

什么是图

其实很简单,把点用边连起来就可以算是图。

从严格意义上来讲,图是一种数据结构,定义为:graph=(V,E)。其中,V 是一个非空有限集合,代表顶点(结点),E 代表边的集合。

图的一些定义和概念

  • 有向图:图的边有方向,只能严格遵循箭头方向从一个点到达另一个点。例如下方就是一个有向图:有向图实例
  • 无向图:图的边有方向,可以双向行走。例如下方就是一个无向图:无向图实例
  • 结点的度:仅存在在无向图中。无向图中与一个结点相连的边的个数叫做这个结点的度。
  • 结点的入度:仅存在在有向图中。有向图中以一个结点为终点的边的个数叫做这个结点的入度。
  • 结点的出度:仅存在在有向图中。有向图中以一个结点起点的边的个数叫做这个结点的出度。
  • 权值:边的“费用”,可以理解为边的长度。
  • 连通:如果图中存在一条从结点 U U U 到结点 V V V 的道路,则称 U U U V V V 是连通的。
  • 回路:起点和终点为同一结点的路径叫做回路,或称为“环”。
  • 完全图:一个有 n n n 个结点的有向图有 n × ( n − 1 ) n\times(n-1) n×(n1) 条边或一个有 n n n 个结点的无向图有 n × ( n − 1 ) 2 \frac{n\times(n-1)}2 2n×(n1) 条边。
  • 稠密图:一个边数接近完全图的图。
  • 稠密图:一个边数远远少于完全图的图。
  • 强连通分量:有向图中任意两点都连通的最大子图。下图中的 1 1 1 2 2 2 5 5 5 结点就构成一个强连通分量。特殊的,单个点也算一个强连通分量。所以下图中有 3 3 3 个强连通分量: 1 − 2 − 5 1-2-5 125 3 3 3 4 4 4强连通分量

图的存储方式

这里只讲解最常见的邻接表和邻接矩阵。

二维数组邻接矩阵存储

定义 int 类型数组:G[100][100](注:数组大小随结点的个数变化)。

G i , j G_{i,j} Gi,j 的值表示从点 i i i 到点 j j j 的权值,定义如下:
G i , j = { 1  或权值 v i  与  v j  之间有边或弧 0  或  ∞ v i  与  v j  之间无边且无弧 G_{i,j}=\begin{cases} 1\ \textrm{或权值}&v_i\ \textrm{与}\ v_j\ \textrm{之间有边或弧}\\ 0\ \textrm{或}\ \infty&v_i\ \textrm{与}\ v_j\ \textrm{之间无边且无弧} \end{cases} Gi,j={1 或权值0  vi  vj 之间有边或弧vi  vj 之间无边且无弧邻接矩阵示例图1邻接矩阵示例图2邻接表矩阵示例图3
上面的 3 3 3 个图对应的邻接矩阵分别如下:
G ( A ) = [ 0 1 1 1 1 0 1 1 1 1 0 0 1 1 0 0 ] G ( B ) = [ 0 1 1 0 0 1 0 1 0 ] G ( C ) = [ ∞ 5 8 ∞ 3 5 ∞ 2 ∞ 6 8 2 ∞ 10 4 ∞ ∞ 10 ∞ 11 3 6 4 11 ∞ ] G(A)=\begin{bmatrix} 0&1&1&1\\ 1&0&1&1\\ 1&1&0&0\\ 1&1&0&0 \end{bmatrix}\qquad G(B)=\begin{bmatrix} 0&1&1\\ 0&0&1\\ 0&1&0 \end{bmatrix}\qquad G(C)=\begin{bmatrix} \infty&5&8&\infty&3\\ 5&\infty&2&\infty&6\\ 8&2&\infty&10&4\\ \infty&\infty&10&\infty&11\\ 3&6&4&11&\infty \end{bmatrix} G(A)= 0111101111001100 G(B)= 000101110 G(C)= 58352682104101136411

优缺点

优点:实现简单,使用方便,且容易获取每个结点的度(有向图是入度和出度),特别是有向图的出度,有手就会。
缺点:对于节点多,边数少的图来说,邻接矩阵存储很浪费空间。

以空间换时间。

数组模拟邻接表存储

图的邻接表存储法,又叫链式存储法。本来是采用链表实现的,但大多情况下只要用数组模拟即可。

优缺点

优点:随机数据下空间相对较小。
缺点:极限数据浪费空间大。

空间消耗不稳定。

边集数组优缺点

优点:更加的节约空间。
缺点:搜索时需要把所有的边枚举一遍,太浪费时间。

以时间换空间。

排序前向星优缺点

优点:更加的节约空间。
缺点:排序时间大。

以时间换空间。

链式前向星优缺点

优点:空间消耗少,速度也快。
缺点:暂无。

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

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

相关文章

使用docker搭建GitLab个人开发项目私服

一、安装docker 1.更新系统 dnf update # 最后出现这个标识就说明更新系统成功 Complete!2.添加docker源 dnf config-manager --add-repohttps://download.docker.com/linux/centos/docker-ce.repo # 最后出现这个标识就说明添加成功 Adding repo from: https://download.…

【数据结构】顺序表:与时俱进的结构解析与创新应用

欢迎来到白刘的领域 Miracle_86.-CSDN博客 系列专栏 数据结构与算法 先赞后看,已成习惯 创作不易,多多支持! 目录 一、数据结构的概念 二、顺序表(Sequence List) 2.1 线性表的概念以及结构 2.2 顺序表分类 …

SpringMVC深解--一起学习吧之架构

SpringMVC的工作原理主要基于请求驱动,它采用了前端控制器模式来进行设计。以下是SpringMVC工作原理的详细解释: 请求接收与分发: 当用户发送一个请求到Web服务器时,这个请求首先会被SpringMVC的前端控制器(Dispatche…

ExpertPrompting:指导大语言模型成为杰出专家

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 论文标题:ExpertPrompting: Instructing Large Language Models to be Distinguished Experts 论文地址:https://arxiv.org/abs/2305.14688 作者 & 机构:Benfen…

【号码工具】批量手机号码归属地查询,一次性查询40万个,如何大批量的进行手机号码归属地查询

前言: 批量的筛选出一个地区的手机号码、批量查询一批号码的归属地,按城市分类,按省份分类,按运营商分类,都可以,比如我想找广东省的,那么查询好后,就按照省进行分类,找…

Spring Security之Session管理

前言 在聊认证过滤器的时候,我们埋了个坑:Session管理。实际上,事情从这里开始,就变得复杂了。提前跟大家交个底:后续我们将涉及多个需要协同才能完成的功能。 什么是Session 想要管理session,就必须搞清…

分析和比较深度学习框架 PyTorch 和 Tensorflow

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 深度学习作为人工智能的一个重要分支,在过去十年中取得了显著的进展。PyTorch 和 TensorFlow 是目前最受欢迎、最强大的两个深度学习框架,它们各自拥有独特的特点和优势。 1. Py…

Llama 3大模型发布!快速体验推理及微调

Meta,一家全球知名的科技和社交媒体巨头,在其官方网站上正式宣布了一款开源的大型预训练语言模型——Llama-3。 据了解,Llama-3模型提供了两种不同参数规模的版本,分别是80亿参数和700亿参数。这两种版本分别针对基础的预训练任务…

【系统分析师】软件工程

文章目录 1、信息系统生命周期2、软件开发模型2.1 原型及其演化2.2 增量模型和螺旋模型2.3 V模型、喷泉模型、快速应用开发2.4 构件组装模型2.5 统一过程-UP2.6 敏捷方法 3、逆向工程4、净室软件工程 【写在前面】 记录了一系列【系统分析师】文章,点击下面的链接&a…

【Kyuubi】Apache Kyuubi 1.8 特性解读

Apache Kyuubi 1.8 特性解读 1.Apache Kyuubi 简介2.场景扩展 —— 在线分析,离线跑批3.流式增强 —— 流批一体,面向未来4.企业特性 —— 行业沉淀,持续打磨5.开源社区 —— 开放包容,合作共赢 本文来自于 Apache Kyuubi PMC Mem…

数据结构与算法解题-20240421

数据结构与算法解题-20240421 一、278. 第一个错误的版本二、541. 反转字符串 II三、右旋字符串四、替换数字五、977.有序数组的平方 一、278. 第一个错误的版本 简单 你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有…

深度学习-优化策略

1.使用众所周知的梯度下降法。 (1).批量梯度下降法:每次参数更新使用所有的样本(2).随机梯度下降法:每次参数更新只使用一次样本(3).小批量梯度下降法:每次参数更新使用…

【python】启动一个公司级项目的完整报错和解决方案

启动一个项目对于新手都是不容易的事情 操作 打开项目 使用pyCharm打开python项目以后,先找main方法,一般在根目录有一个.py的文件 点进去以后会让你配置Python解释器 每个项目都有自己的一个虚拟环境,配置自己的解释器,可能…

Gitea 简单介绍、用法以及使用注意事项!

Gitea 是一个轻量级的代码托管解决方案,它提供了一个简单而强大的平台,用于托管和协作开发项目。基于 Go 语言编写,与 GitLab 和 GitHub Enterprise 类似,但专为自托管而设计。以下是对 Gitea 的详细介绍,包括常用命令…

【语音识别】在Win11使用Docker部署FunASR服务器

文章目录 在 Win11 使用 Docker 部署 FunASR 服务器镜像启动服务端启动监控服务端日志下载测试案例使用测试案例打开基于 HTML 的案例连接ASR服务端 关闭FunASR服务 在 Win11 使用 Docker 部署 FunASR 服务器 该文章因官网文档不详细故写的经验论 官网文章:https:/…

Wpf 使用 Prism 实战开发Day21

配置默认首页 当应用程序启动时&#xff0c;默认显示首页 一.实现思路&#xff0c;通过自定义接口来配置应用程序加载完成时&#xff0c;设置默认显示页 步骤1.创建自定义 IConfigureService 接口 namespace MyToDo.Common {/// <summary>/// 配置默认显示页接口/// <…

Android Studio Emulator一直卡在Google Logo出不来

我尝试在androidstudio模拟器中运行我的应用程序&#xff0c;模拟器已经打开&#xff0c;但一直停留在Google徽标加载界面半个小时了都退不出来&#xff0c;也进不去。 解决方案如下&#xff1a; 我们创建模拟设备的时候&#xff0c;界面上会显示&#xff1a; 1.不要使用带有…

贝叶斯分类 python

贝叶斯分类 python 贝叶斯分类器是一种基于贝叶斯定理的分类方法&#xff0c;常用于文本分类、垃圾邮件过滤等领域。 在Python中&#xff0c;我们可以使用scikit-learn库来实现贝叶斯分类器。 下面是一个使用Gaussian Naive Bayes(高斯朴素贝叶斯)分类器的简单示例&#xff1…

使用Python进行云计算:AWS、Azure、和Google Cloud的比较

&#x1f47d;发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 使用Python进行云计算&#xff1a;AWS、Azure、和Google Cloud的比较 随着云计算的普及&am…

Linux-软件安装--jdk安装

jdk安装 前言1、软件安装方式二进制发布包安装rpm安装yum安装源码编译安装 2、安装jdk2.1、使用finalShell自带的上传工具将jdk的二进制发布包上传到Linux2.2、解压安装包2.3、配置环境变量![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/61ba9750e2e34638a39575c5…